《C语言》课内实验报告.doc

上传人:文库蛋蛋多 文档编号:2385114 上传时间:2023-02-17 格式:DOC 页数:14 大小:91.50KB
返回 下载 相关 举报
《C语言》课内实验报告.doc_第1页
第1页 / 共14页
《C语言》课内实验报告.doc_第2页
第2页 / 共14页
《C语言》课内实验报告.doc_第3页
第3页 / 共14页
《C语言》课内实验报告.doc_第4页
第4页 / 共14页
《C语言》课内实验报告.doc_第5页
第5页 / 共14页
点击查看更多>>
资源描述

《《C语言》课内实验报告.doc》由会员分享,可在线阅读,更多相关《《C语言》课内实验报告.doc(14页珍藏版)》请在三一办公上搜索。

1、C语言课内实验报告学生姓名:及 学 号:学 院:理学院班 级:数学111课程名称:C语言实验题目:结构体的应用指导教师姓名及职称: 2012年06月05日一、实验题目:结构体的应用二、实验目的:1进一步掌握结构体变量、数组的定义和使用方法,掌握结构体与指针的应用。2学习共用体的概念和使用。3学习链表的概念和使用。三、实验内容:1有6个学生,每个学生的数据包括学号、姓名、性别、4门课的成绩、总成绩、平均成绩。从键盘输入每个学生信息及4门课成绩,总成绩及平均成绩要通过4门课算出。然后用选择排序法按照总成绩由高到低对6个学生数据进行排序并输出排序结果。要求输入、排序、输出用3个自定义函数实现。编写源

2、程序,给出注释及运行结果。(提示,请参阅教材上292页例11.5及例11.6的程序)。2建立一个含有10个结点的单链表,每个节点包括:学号、姓名、性别、年龄和一门课程的成绩。输入一个学号,删去等于此学号的结点;按学号排序向原单链表中插入两个新结点。编写源程序,给出注释及运行结果。(提示,请参阅教材上297页至308页例11.8-例11.11的程序)。四、实验结果:1.程序如下:#include /*连接库函数stdio.h*/struct student /*声明结构体类型struct student,并定义此结构体类型的数组stu6*/int s_no; /*定义整形变量s_no于结构体类型

3、struct student中*/char s_name10; /*定义字符数组s_name于结构体类型struct student中*/char s_sex; /*定义字符形变量s_sex于结构体类型struct student中*/float s_score4; /*定义浮点形数组s_score于结构体类型struct student中*/float sum; /*定义浮点形变量sum于结构体类型struct student中*/float average; /*定义浮点形变量average于结构体类型struct student中*/stu6;struct student *input(

4、struct student *stu,int n) /*定义函数input(struct student *stu,int n),此函数返回指向struct student类型数据的指针*/struct student *p; /*定义指向struct student类型数据的指针p*/int i; /*定义整型变量i*/p=stu; /* p=stu*/printf(please input the infomation of student:nn); /*输出” please input the infomation of student”*/printf( no name sex sc

5、ore1 score2 score3 score4n); /*输出”no name sex score1 score2 score3 score4”*/for(i=0;in;i+,p+) /*i=0;当is_no,p-s_name,&p-s_sex,&p-s_score0,&p-s_score1,&p-s_score2,&p-s_score3); /*输入struct student所需的数据,储存在p指向的变量的地址*/return(&stu0); /*函数返回&stu0的值*/void output(struct student *p,int n) /*定义空型函数output(struc

6、t student *p,int n)*/int i; /*定义整型变量i*/printf(nnthe information of the students is:nn); /*输出”the information of the students is:”*/printf(no name sex score1 score2 score3 score4 sum averagen); /*输出no name sex score1 score2 score3 score4 sum average”*/ for(i=0;in;i+) /*i=0;当is_no,pi-s_name,pi-s_sex,p

7、i-s_score0,pi-s_score1,pi-s_score2,pi-s_score3,pi-sum,pi-average); /*输出pi所指向变量的各个数据*/void count(struct student *stu,int n) /*定义空型函数count(struct student *stu,int n)*/struct student *p; /*定义指向struct student类型变量的指针p*/int i; /*定义整型变量i*/p=stu; /* p=stu*/for(i=0;in;i+,p+) /*i=0;当isum=p-s_score0+p-s_score1

8、+p-s_score2+p-s_score3; /*计算p-sum的值*/p-average=p-sum/4; /* p-average=p-sum/4*/ void sorted(struct student *stu,struct student *p,int n) /*定义空型函数sorted(struct student *stu,struct student *p,int n)*/int i,j,k; /*定义整型变量i,j,k*/struct student *temp; /*定义指向struct student类型变量的指针temp*/ for(i=0;in-1;i+) /*i=

9、0;当in-1时,执行循环,i自加*/k=i; /* k=i*/for(j=i+1;jn;j+) /*j=i+1;当isumsum) /*如果pk-sumsum*/k=j; /* k=j*/if(k!=i) /*如果k!=i*/temp=pi; /* temp=pi; pi=pk; pk=temp;*/ pi=pk;pk=temp;void main() /*空型定义主函数*/int i; /*定义整型变量i*/struct student *p6; /*定义指向struct student类型变量的指针数组p*/for(i=0;i6;i+) /*i=0;当i6时,执行循环,i自加*/pi=s

10、tu+i; /* pi=stu+i*/input(stu,6); /*执行函数input(stu,6)*/count(stu,6); /*执行函数count(stu,6)*/sorted(stu,p,6); /*执行函数sorted(stu,p,6)*/output(p,6); /*执行函数output(p,6)*/程序运行结果如下:2.程序如下:#include /*连接库函数stdio.h*/ #include/*连接库函数malloc.h*/#define LEN sizeof(struct student) /*定义符号常量LEN,为sizeof(struct student)*/st

11、ruct student /*声明结构体类型struct student*/int no; /*定义整形变量no于结构体类型struct student中*/char name20; /*定义字符数组name20 于结构体类型struct student中*/char sex5; /*定义字符数组sex5 于结构体类型struct student中*/int age; /*定义整形变量age于结构体类型struct student中*/float score; /*定义浮点型变量score于结构体类型struct student中*/struct student *next; /*定义指向结构

12、体变量struct student的指针变量next于结构体类型struct student中*/;int n=0; /*定义全局整型变量n=0*/struct student *creat(void) /*定义函数student *creat(void),此函数返回指向struct student类型数据的指针*/struct student *p1,*p2,*head; /*定义指向struct student类型变量的指针p1,p1,head*/int k=1; /*定义整型变量k=1*/head=NULL; /* head=NULL ;n=0*/n=0;p1=p2=(struct st

13、udent *)malloc(LEN); /*开辟LEN大小的空间令p1,p2指向空间的首地址*/if(p1!=NULL) /*如果p1!=NULL*/printf(%sn,请输入学生信息); /*输出“请输入学生信息”*/printf(%sn,学号 姓名 性别 年龄 成绩); /*输出“学号 姓名 性别 年龄 成绩”*/ scanf(%d%s%s%d%f,&p1-no,p1-name,p1-sex,&p1-age,&p1-score);/*输入struct student所需的数据,储存在p1指向的变量的地址*/while(k!=2) /*当k!=2时,执行循环*/n=n+1; /* n=n

14、+1*/if(n=1) head=p1; /*如果n=1,head=p1*/else p2-next=p1; /*否则p2-next=p1*/p2=p1; /* p2=p1*/printf(%s,是否继续 1 是;2 否 ); /*输出“是否继续 1 是;2 否”*/scanf(%d,&k); /*输入k的值*/if(k=2) break; /*如果k=2,跳出循环*/p1=(struct student *)malloc(LEN); /*开辟LEN大小的空间令p1指向空间的首地址*/if(p1!=NULL) /*如果p1!=NULL*/ scanf(%d%s%s%d%f,&p1-no,p1-

15、name,p1-sex,&p1-age,&p1-score);/*输入struct student所需的数据,储存在p1指向的变量的地址*/ else goto loop; /*否则跳到loop标记的程序*/ p2-next=NULL; /* p2-next=NULL*/return(head); /*返回head作为函数的返回值*/elseloop: printf(%s,内存不够,无法建立链表); /*否则输出“内存不够,无法建立链表”并用loop标记*/return(head); /*返回head作为函数的返回值*/struct student *insert(struct student

16、 *head)/*定义函数insert(struct student *head),此函数返回指向struct student类型数据的指针*/struct student *p1,*p2,*p0; /*定义指向struct student类型变量的指针p1,p1,p0*/p2=p1=head; /* p2=p1=head */if(head=NULL)printf(n%sn,请先建立学生信息); return(head); /*如果head=NULL,输出“请先建立学生信息”,返回dead*/p0=(struct student *)malloc(LEN); /*开辟LEN大小的空间令p0指

17、向空间的首地址*/printf(%sn,请输入学生信息); /*输出“请输入学生信息”*/ printf(%sn,学号 姓名 性别 年龄 成绩); /*输出“学号 姓名 性别 年龄 成绩”*/ scanf(%d%s%s%d%f,&p0-no,p0-name,p0-sex,&p0-age,&p0-score); /*输入struct student所需的数据,储存在p0指向的变量的地址*/if(head=NULL) /*如果(head=NULL*/head=p1;p1-next=NULL;n+; /* head=p1;p1-next=NULL;n+*/printf(n%sn,学生信息添加成功);

18、 /*输出“学生信息添加成功”*/else /*否则*/while(p0-nop1-no&p1-next!=NULL) /*当p0-nop1-no且p1-next!=NULL执行循环*/p2=p1; /* p2=p1; p1=p1-next;*/ p1=p1-next; if(p1-next=NULL) /*如果p1-next=NULL*/p1-next=p0; /* p1-next=p0;p0-next=NULL;n+;*/p0-next=NULL;n+;printf(n%sn,学生信息添加成功); /*输出“学生信息添加成功”*/else /*否则*/p2-next=p0; /* p2-n

19、ext=p0;p0-next=p1;n+;*/p0-next=p1;n+;printf(n%sn,学生信息添加成功); /*输出“学生信息添加成功”*/return(head); /*函数返回head*/struct student *del(struct student *head) /*定义函数insert(struct student *head),此函数返回指向struct student类型数据的指针*/struct student *p1,*p2; /*定义指向struct student类型变量的指针p1,p1*/int num; /*定义整型变量num*/printf(%s,请

20、输入要删除学生的学号:); /*输出“请输入要删除学生的学号”*/scanf(%d,&num); /*输入num的值*/p2=p1=head; /* p2=p1=head*/if(p1=NULL) /*如果p1=NULL*/ printf(n%sn,此链表为空,无法删除); /*输出此链表为空,无法删除*/else /*否则*/while(p1-no!=num & p1-next!=NULL) /*当(p1-no!=num且p1-next!=NULL时执行循环*/p2=p1; /* p2=p1; p1=p1-next;*/p1=p1-next;if(p1-next=NULL&p1-no!=nu

21、m) /*如果p1-next=NULL且p1-no!=num*/printf(n%sn,无此学生的信息); /*输出“无此学生的信息”*/else /*否则*/if(p1=p2) /*如果p1=p2*/head=p1-next;n-; /* head=p1-next;n-*/printf(n%sn,学生信息删除成功); /*输出“学生信息删除成功”*/else /*否则*/p2-next=p1-next;n-; /* p2-next=p1-next;n-*/printf(n%sn,学生信息删除成功); /*输出“学生信息删除成功”*/return(head); /*函数返回head*/void

22、 output(struct student *head) /*定义空型函数output(struct student *head)*/struct student *p; /*定义指向struct student类型变量的指针p*/p=head; /* p=head*/printf(%s%d%snn,此链表有,n,条信息); /*输出“此链表有,n,条信息”*/if(head!=NULL) /*如果head!=NULL*/printf(%sn,学号 姓名 性别 年龄 成绩); /*输出“学号 姓名 性别 年龄 成绩”*/while(p!=NULL) /*当p!=NULL时,执行循环*/pri

23、ntf(%-4d%5s%-4s%-5d%-7.2fn,p-no,p-name,p-sex,p-age,p-score); /*输出p1所指向变量的各个数据*/p=p-next; /* p=p-next*/int index() /*定义返回整形数据的函数index()*/int flag; /*定义整型变量flag*/printf(n*%s*nn,学生信息管理系统); /*输出“*学生信息管理系统*”*/printf( 1%sn,建立学生信息); /*输出“1建立学生信息”*/ printf( 2%sn,添加学生信息); /*输出“2添加学生信息”*/printf( 3%sn,删除学生信息);

24、 /*输出“3删除学生信息”*/printf( 4%sn,显示学生信息); /*输出“4显示学生信息”*/printf( 0%snn,退出); /*输出“0退出”*/printf( %s,请选择: ); /*输出“请选择”*/scanf(%d,&flag); /*输入flag的值*/ return(flag); /*函数返回flag*/void main() /*定义空型主函数*/ struct student *head=NULL; /*定义指向struct student类型变量的指针head=NULL*/ int flag; /*定义整型变量flag*/ flag=index(); /*

25、 flag=index()*/ while(flag!=0) /*当flag!=0时,执行循环*/switch(flag) /*如果*/case 1:head=creat();flag=index();break; /*flag=1,head=creat();flag=index();结束switch语句*/;case 2:head=insert(head);flag=index();break; /*flag=2,head=insert();flag=index();结束switch语句*/case 3:head=del(head);flag=index();break; /*flag=3,

26、head=del();flag=index();结束switch语句*/case 4:output(head);flag=index();break; /*flag=4,head=output();flag=index();结束switch语句*/default:printf(%s,选择错误),flag=index(); /*否则,输出“选择错误”, flag=index()*/程序运行结果如下:1建立链表:2删除链表结点:3添加链表结点:五、实验体会或遇到问题:这次课内试验虽然题数少了,但每一题的复杂程度都比较大,逻辑也比较复杂。在编出程序之后,出现了各种各样的逻辑错误,但由于经过比较多的训练,对于各种逻辑错误,有了比较成熟和有效的调试方法,所以本次试验程序的调试还是比较顺利的。但有一些错误是听取了别人的建议之后才调试出来的,所以,与人交流也是很重要的。另外,我觉得到目前为止,在实验报告中,对程序单句注释不仅耗费比较多的时间,而且意义已经不大,所以我希望在以后的程序中,采取功能注释的方法,希望老师能够考虑。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑/施工/环境 > 项目建议


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号