panmmmy 发表于 2021-12-18 19:48:17

求问这个程序是怎么实现的?

#include <stdio.h>

void sort(int a[], int n) {
        int i,j,t;

        for(i = 0; i < n - 1; i ++)

                for( j = i + 1; j < n; j ++)

                        if(a < a) {

                                t = a;
                                a = a;
                                a = t;


                        }

}

int main() {

        int aa = {1, 2, 3, 4, 5, 6}, i;

        sort(&aa, 5);

        for(i = 0; i < 6; i ++)

                printf("%4d", aa);

        printf("\n");


        return 0;
}


问题:调用sort函数后,返回的是什么?为什么会影响aa[]这个数组




monkey-D 发表于 2021-12-18 20:06:11

sort函数不返回东西啊,void的都不返回东西
调用sort的时候把aa数组的地址传进去了,不是将整个aa数组中的元素当形参传进去,所以在sort函数中改值会直接改aa数组的值

傻眼貓咪 发表于 2021-12-18 20:23:58

本帖最后由 傻眼貓咪 于 2021-12-18 20:44 编辑

#include <stdio.h>

void sort(int *a, int n){
    for(int i = 0; i < n-1; i++)
    for(int j = i+1; j < n; j++)
    if(*(a+i) < *(a+j)){
      *(a+i) -= *(a+j);
      *(a+j) += *(a+i);
      *(a+i) = *(a+j)-*(a+i);
    }
}

int main()
{
    int nums[] = {1, 2, 3, 4, 5, 6};
    int n = sizeof(nums)/sizeof(int);
    sort(nums, n);
    for(int i = 0; i < n; i++) printf("%d ", *(nums+i));
    return 0;
}

jackz007 发表于 2021-12-18 22:10:10

本帖最后由 jackz007 于 2021-12-18 22:11 编辑

      因为你传给 sort() 的参数是 & aa,也就是数组 aa 从索引为 1 的元素开始的起始内存地址,在 sort() 函数内,将会实现从 aa ~ aa数组元素顺序的重排。所以,调用过函数后,再次打印 aa 的时候,会发现,aa 的数组元素已经发生了改变。
页: [1]
查看完整版本: 求问这个程序是怎么实现的?