在 Deitel 的 C 如何编程的第 7 章中,作者使用冒泡排序示例来说明信息隐藏不允许函数知道单个数组元素,指针可用于传递地址并以相同的方式使用。
这是使用指针的交换函数:
void swap( int *element1Ptr, int *element2Ptr ) {
int hold = *element1Ptr;
*element1Ptr = *element2Ptr;
*element2Ptr = hold;
}
这是我所做的:
void swap(int array[],int j) {
int hold = array[j];
array[j] = array[j + 1];
array[j + 1] = hold;
}
主要的():
int main(void) {
int b[] = {2,6,4,8,10,12,89,68,45,37};
for (int i = 0; i < 9; i++) {
for (int n = 0; n < 9; n++) {
if (b[n] > b[n + 1]) {
swap(&b[n], &b[n+1]); // or swap(b,n);
}
}
}
for (int i = 0; i < 9; i++) {
printf("%d ", b[i]);
}
puts("");
return 0;
}
我运行了代码并且都正确地对数组进行了排序。所以我认为我的函数实际上获得了对单个元素的访问权限。我理解错了哪一部分?在继续之前,我需要确保我理解每一点,因为跳过一个确实会使即将到来的内容难以掌握。