- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
阅读程序写结果构结体与共用体答案
1.以下程序段的运行结果是【1】
struct date
{ int year,month,day; } today;
main()
{ printf(%d\n,sizeof(struct date)); }
答案:struct date有三个成员,每个成员占4个字节,所以运行结果:
3×4=12
2.以下程序段的运行结果是【2】
struct st { int x; int *y;} *p;
int dt[4]={ 10,20,30,40 };
struct st aa[4]={ 50,dt[0],60,dt[1],60,dt[2],60,dt[3] };
main()
{ p=aa; printf(%d\n,++(p-x)); }
答案:p指向aa[0],++(p-x)的执行结果:aa[0]的x成员增1
3.以下程序段的运行结果是【3】
union pw { int i; char ch[2];}a;
main()
{ a.ch[0]=13; ch[1]=0;
printf(%d\n,a.i); }
答案:忽略
4.以下程序段的运行结果是【4】
struct abc
{ int a, b, c, s; };
main()
{ struct abc s[2]={{1,2,3},{4,5,6}};
int t; t=s[0].a + s[1].b;
printf(%d\n,t); }
答案:s是一个结构数组,初始化的结果:s[0].a=1,s[0].b=2,s[0].c=3,s[0].s=0,s[1].a=4,s[1].b=5,s[1].c=6,s[1].s=0
t的值为:s[0].a(1)+ s[1].b(5)=6
输出结果:6
5.以下程序段的运行结果是【5】
struct st
{ int x; int *y; } *p;
int dt[4]={10,20,30,40};
struct st aa[4]={ 50,dt[0],60,21,70,dt[2],80,dt[3]};
main()
{ p=aa; 答案:
printf(%d\n,++p-x); 51
printf(%d\n,(++p)-x); 60
printf(%d\n,++(*p-y)); } 21
6.以下程序段的运行结果是【6】
union myun
{ struct
{ int x, y, z; } u;
int k;} a;
main()
{ a.u.x=4; a.u.y=5; a.u.z=6; a.k=0;
printf(%d\n,a.u.x);
}
答案:忽略
7.以下程序段的运行结果是【7】
struct STU
{ char num[10]; float score[3];};
main()
{ struct STU s[3]=
{ {20021,90,95,85},{20022,95,80,75},{20023,100,95,90} };
struct STU *p=s; int i; float sum=0;
for(i=0;i3;i++)sum=sum+p-score[i];
printf(%6.2f\n,sum); }
答案:p指向s[0], sum求的是s[0]的三个成绩和,结果:270
8.以下程序段的运行结果是【8】
struct NODE
{ int num; struct NODE *next; };
main()
{ struct NODE *p,*q,*r;
p=(struct NODE*)malloc(sizeof(struct NODE));
q=(struct NODE*)malloc(sizeof(struct NODE));
r=(struct NODE*)malloc(sizeof(struct NODE));
p-num=10; q-num=20; r-num=30;
p-next=q;q-next=r;
printf(%d\n ,p-num+q-next-num);
}
答案:p,q,r分别指向三个结点,p-num+q-next-num,就是:
p-num + r-num ,即:10+30
9.以下程序段的运行结果是【9】
struct a
{ int x;
int y;
}num[2]={{20,5},{6,7}};
main()
{ printf(%d\n,num[0].x/num[0].y*num[1].y);}
答案:num[0].x=20;nu
文档评论(0)