0

在 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;
}

我运行了代码并且都正确地对数组进行了排序。所以我认为我的函数实际上获得了对单个元素的访问权限。我理解错了哪一部分?在继续之前,我需要确保我理解每一点,因为跳过一个确实会使即将到来的内容难以掌握。

4

1 回答 1

0

在 C 中,指针和数组是可以互换的。当您通过索引访问数组元素时,如在 中myArray[x],它的意思是“myArray 的位置 + (x * 数组中元素的大小)”。所以你可以通过做得到同样的结果myArray + (x * sizeof(<type of myArray>));

您可能还想查看这个答案,该答案更深入地了解数组和指针之间的差异。

于 2016-11-25T11:01:48.590 回答