c语言题目问题求详细解释下,谢谢!
inta[5],i,*p;for(i=0;i<=4;i++)a[i]=5-i;p=a;for(i=0;i<3;i++,p++)printf("%4d",p[i]);答案为...
int a[5],i,*p;
for(i=0;i<=4;i++)
a[i]=5-i;
p=a;
for(i=0;i<3;i++,p++)
printf("%4d",p[i]);
答案为什么是 5 3 1
printf("%4d",p[i]);改为printf("%4d",*p) 答案为什么又是5 4 3了,求高手看看!谢谢了 ! 展开
for(i=0;i<=4;i++)
a[i]=5-i;
p=a;
for(i=0;i<3;i++,p++)
printf("%4d",p[i]);
答案为什么是 5 3 1
printf("%4d",p[i]);改为printf("%4d",*p) 答案为什么又是5 4 3了,求高手看看!谢谢了 ! 展开
5个回答
展开全部
请仔细看了
int a[5],i,*p;
for(i=0;i<=4;i++)
a[i]=5-i;
p=a;
这些语句执行后是a数组{5,4,3,2,1} p指向a[0] (a[0]的值为5)
下面是主要的
for(i=0;i<3;i++,p++)
printf("%4d",p[i]);
1. 一开始i=0, p是a[0]的地址 (a[0]的值为5) p[i]就是a[0]这个地址往后移i (即0)个存储单位后的存储单位的值,所以是a[0]的值5。
2.然后i=1了 p是a[1]的地址 p[i]就是a[1]这个地址往后移i (即1)个存储单位后的存储单位的值,所以是a[2]的值3。
3.然后i=2了 p是a[2]的地址
p[i]就是a[2]这个地址往后移i (即2)个存储单位后的存储单位的值,所以是a[4]的值1。
4.i=3 退出循环。
如果改为printf("%4d",*p)则p不后移的值,所以是5,4,3
展开全部
当指针带有一维下标使用时,总是把指针的当前值作为下标零的数组元素来处理的。
所以:p=a; 之后,p[0] 就是 a[0]
输出了 5
之后 p++,使得p记录 a[1] 地址,即p[0] 指的是a[1]; p[1] 表示的是 a[2]
所以输出了 3
同样道理,第三次,输出的就是1了。
所以:p=a; 之后,p[0] 就是 a[0]
输出了 5
之后 p++,使得p记录 a[1] 地址,即p[0] 指的是a[1]; p[1] 表示的是 a[2]
所以输出了 3
同样道理,第三次,输出的就是1了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
a[0~5]分别是5 4 3 2 1这个没问题吧,下面i=0时输出p[0],i++变为1,p++变为p[2],然后输出p[2],i++变为3,p++变为4,输出p[4],此时i是4,大于3,结束。
主要注意*p是指针,p++相当于i++
主要注意*p是指针,p++相当于i++
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
很明显的错误嘛,你要不递增索引号i要不递增指针p,两个一起递增自然每次都会跳过一个数了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
p储存的地址指向数组a的首地址p++指向数组下一值,*p是取其指向的内存中的值,所以后一种是取啊a[0],a[1],a[2],的值5 4 3,而p[i]则是在现有的基础上在移动i元素位置,所以i=0时,P[i]指向a[0+i]值为5,i=1时,p[i]指向a[1+i],值为3,当i=2时是1,这样就得到了5,3,1
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询