題目要求
求該代碼最後的輸出結果
#include<stdio.h> int f1(int n[]) { n[0] = n[0] + 1; } int main() { int n[3]={1,2,3}; int i; f1(n); for(i=0;i<3;i++) { printf("n[%d]=%d\n",i,n[i]); } return 0; }
思路分析
首先得知道f1( int n [ ])的int n[ ],和下面的int n[3]={1,2,3},是一樣的 數組默認以"地址"的方式傳遞(傳遞指針)
簡單來說,在main函數中n[3]的位置存放在計算機內存的"棧" 中 n---->[1,2,3]
f1函數中的n[ ]也再存放計算機內存中,不過是另一個"棧"中 n---->[1,2,3]
在f1函數中,要n[0] = n[0]+1變成了n[1] ,因爲地址一樣,n[0]在main函數中對應的元素爲"1",n[1]在main函數中對應的元素爲"2",
所以最後的輸出結果應該爲 2,2,3
查看結果
#include<stdio.h>
int f1(int n[])
{
printf("f1函數中n的地址 = %p \n",n);
n[0] = n[0] + 1;
}
int main()
{
int n[3]={1,2,3};
int i;
printf("main函數中n的地址 = %p \n",n); //%p是打印地址
f1(n);
for(i=0;i<3;i++)
{
printf("n[%d]=%d\n",i,n[i]);
}
return 0;
}