求问这个程序是怎么实现的?
#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[]这个数组
sort函数不返回东西啊,void的都不返回东西
调用sort的时候把aa数组的地址传进去了,不是将整个aa数组中的元素当形参传进去,所以在sort函数中改值会直接改aa数组的值 本帖最后由 傻眼貓咪 于 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:11 编辑
因为你传给 sort() 的参数是 & aa,也就是数组 aa 从索引为 1 的元素开始的起始内存地址,在 sort() 函数内,将会实现从 aa ~ aa数组元素顺序的重排。所以,调用过函数后,再次打印 aa 的时候,会发现,aa 的数组元素已经发生了改变。
页:
[1]