网站大量收购独家精品文档,联系QQ:2885784924

第8章c语言习题答案.docVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
练习与思考 8 8.1 选择题 (1)有以下定义及语句,则对数组a元素的不正确引用的表达式是( )。int a[4][5];*p[2],j; for (j = 0 ; j 4 ; j++) p[j]=a[j]; A)p[0][0] B)*(a+3)[4] C)*(p[1]+2) D)*(a[0][0]+3) () 有以下程序 #include stdio.h struct tt {int x;struct tt *y;} *p; struct tt a[4]={20,a+1,15,a+2,30,a+3,17,a}; main() { int i; p=a; for(i=1;i=2;i++) {printf(%d,,p-x); p=p-y;} } 程序的运行结果( )。 A)20,30, B)30,17 C)15,30, D)20,15,.2 填空题 (1) 以下程序段的输出结果是( )。 #include stdio.h #define F(a,b) printf(%d,%d\n,a,b) void main() { int a[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}}; F(a,a[0]); F(*a,*(a+0)); F(a[1],*(a+1)); F(*a[1],**(a+1)); F(*(a[1]+1),*(*(a+1)+1)); F(*a,**a); } () 以下程序的运行时,输入i=1,j=2(回车)结果是( )。 #include stdio.h void main() { int a[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}}; int (*p)[4],i,j; p=a; scanf(i=%d,j=%d,i,j); printf(a[%d][%d]=%d\n,i,j,*(*(p+i)+j)); } (3) 以下程序运行后的输出结果是( )。 struct NODE { int k; struct NODE *link; }; main() { struct NODE m[5],*p=m,*q=m+4; int i=0; while(p!=q){ p-k=++i; p++; q-k=i++; q--; } q-k=i; for(i=0;i5;i++) printf(%d,m[i].k); printf(\n); } (4) 以下程序运行后的输出结果是( )。 struct NODE { int num; struct NODE *next; } ; main() { struct NODE s[3]={{1, \0},{2, \0},{3, \0}}, *p, *q, *r; int sum=0; s[0].next=s+1; s[1].next=s+2; s[2].next=s; p=s; q=p-next; r=q-next; sum+=q-next-num; sum+=r-next-next-num; printf(%d\n, sum); } (5) 以下程序的输出结果是( )。 #include stdio.h main() {char *s1,*s2,m; s1=s2=(char*)malloc(sizeof(char)); *s1=15; *s2=20; m=*s1+*s2; printf(%d\n,m); }.3 编程题 () 27人围成一个圈,从第1个人开始顺序报号,凡报号为3和3的倍数者退出圈子,找出最后留在圈子中的人原来的序号(用链表方式实现)。.4 简答题 () 调试运行下列程序,并回答问题。 int max, n; main ( ) { int a[4][4], j, k; for (j=0; j4; j++) for (k=0; k4; k++) scanf(%d ,a[j][k]); printf (\n); for (j=0; j4; j++) printf (%d %d %d %d\n ,a[j][0], a[j][1] , a[j][2], a[j][3] ); maxgs(a,4); printf (max=%d , count=%d\n ,max,n ); } maxgs(b,m) int b[][4], m; { int j, k; max =b[0][0]; for (j=0; jm; j++) for (k=0; km; k++) if (maxb[j][k] ) max=b[j][

文档评论(0)

wuyoujun92 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档