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

实验16 结构体和用体实验16 结构体和共用体.doc

实验16 结构体和用体实验16 结构体和共用体.doc

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验16 结构体和共用体 实验时间:12月26日星期三34节 实验地点:2机房 一、实验实训目的及要求 掌握结构体的类型变量的定义和使用; 2、掌握结构体类型数组的概念和应用; 3、掌握链表和概念,初步学会对链表进行操作; 4、掌握共用体的概念与使用。 二、实验实训内容 与 实验实训指导 (1)有10个学生,每个学生的数据包括学号、姓名、3门课的成绩,从键盘输入5个学生数据,要求输出3门课总平均成绩,以及最高分的学生的数据(包括学号、姓名、3门课的成绩、平均分数) 要求用一个input函数输入5个学生数据;用一个average函数求总平均分;用max函数找出最高分学生数据;总平均分和最高分的学生的数据都在主函数中输出。 参考程序: #define N 10 struct student {char num[6] char name[8] int score[4] float avr; }stu[N]; main() {int I,j,max,maxi,sum; float average; for(I=0;IN;I++) {printf(“\nInput scores of student %d:\n”,I+1); printf(“NO.:”); scanf(“%s”,stu[i].num); printf(“name”); scanf(“%s”,stu[i].name); for(j=0;j3;j++) {printf(“score %d:”,j+1); scanf(“%d”, stu[i].score[j]); } } average=0; max=0; maxi=0; for(i=0;i3;i++) {sum=0; for(j=0;j3;j++) sum+=stu[i].score[j]; stu[i].avr=sum/3.0; average+=stu[i].avr; if(summax) {max=sum; maxi=I; } } average/=N; printf(“NO. name score1 score2 score3 average\n”); for(I=0;IN;I++) {printf(“%5s%10s”,stu[i].num, stu[i].name); for(j=0;j3;j++) printf(“%9d”,stu[i].score[j]); printf(“%8.2f\n”,stu[i].avr); } printf(“average=%6.2f\n”,average); printf(“The highest score is:%s,score total:%d.”stu[maxi].name,max); } (2)13个人围成一圈,从第一个人开始顺序报号1、2、3。凡报到“3”者退出圈子,找出最后留在圈子中的人原来的序号。 #define N 13 struct person {int number; int nextop; }link[N+1]; main() {int I,count,h; for(I=1;I=N;I++) {if(I==N) link[i].nextp=1; else link[i].nextp=I+1; link[i].number=I; } printf(“\n”); count=0; h=N; printf(“sequence that person2 leave the circle:\n”); while(countN-1) {I=0; while(I!=3) {h=link[h].nextp; if(link[h].number) I++; } printf(“%4d”,link[h].number); link[h].number=0; count++; } printf(“\nThe last one is”); for(I=1;ii=N;I++) if(link[i].number) printf(“%3d”,lin[i].number); } (3)建立一个链表,第个节点包括:学号、姓名、年龄。输入一个年龄,如果链表中的节点所包含的年龄

文档评论(0)

skewguj + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档