※ 引述《blueclock (小楊)》之銘言:
: [考題] 國考歷屆考題與考題觀念討論(書裡看到的選這個)請附上想法、出處
: 請問下列 C 程式片段執行後,a 陣列的內容為何?
: #define N 10
: int a[N]={1,2,3,4,5,6,7,8,9,10};
: int *p=&a[0], *q=&a[N-1], temp;
: while(p < q)
: { temp=*p;
: *p++=*q;
: *q--=temp;
: }
: 答案是{10,9,8,7,6,5,4,3,2,1}
: 我的想法是
: p是儲存a[0]的位址
: q是儲存a[9]的位址
: 而a[0]的位址永遠比a[9]小
: 那while為何不會成為無窮迴圈?
您把指標的定義有點搞混了,
先說明,在宣告時,*p指「p」是指標,
但在運算時,*p代表取值,而&a代表取址,
所以宣告int *p=&a[0],是讓他們互為別名,
而程式中的p和q本來就是指標,所以p代表a[0]的內容,q代表a[9]的內容,自然比的就是內容值。
: 再來就是*p和*q的值分別指的是a[0]和a[9]的內容
: 為何做加減也會影響到陣列內其他元素的值?
: 求解惑
您又誤會指標的加減了,*p++,代表的是*p所指的位址++,等同於a[0+1]
同理,*q--,等同於a[9-1]
PS: 教學相長,希望認真的人都考上(包括我T.T)
-----
Sent from JPTT on my Asus ASUS_X00DDA.
--
: [考題] 國考歷屆考題與考題觀念討論(書裡看到的選這個)請附上想法、出處
: 請問下列 C 程式片段執行後,a 陣列的內容為何?
: #define N 10
: int a[N]={1,2,3,4,5,6,7,8,9,10};
: int *p=&a[0], *q=&a[N-1], temp;
: while(p < q)
: { temp=*p;
: *p++=*q;
: *q--=temp;
: }
: 答案是{10,9,8,7,6,5,4,3,2,1}
: 我的想法是
: p是儲存a[0]的位址
: q是儲存a[9]的位址
: 而a[0]的位址永遠比a[9]小
: 那while為何不會成為無窮迴圈?
您把指標的定義有點搞混了,
先說明,在宣告時,*p指「p」是指標,
但在運算時,*p代表取值,而&a代表取址,
所以宣告int *p=&a[0],是讓他們互為別名,
而程式中的p和q本來就是指標,所以p代表a[0]的內容,q代表a[9]的內容,自然比的就是內容值。
: 再來就是*p和*q的值分別指的是a[0]和a[9]的內容
: 為何做加減也會影響到陣列內其他元素的值?
: 求解惑
您又誤會指標的加減了,*p++,代表的是*p所指的位址++,等同於a[0+1]
同理,*q--,等同於a[9-1]
PS: 教學相長,希望認真的人都考上(包括我T.T)
-----
Sent from JPTT on my Asus ASUS_X00DDA.
--
All Comments