C语言程序设计-基于链表的学生成绩管理系统

上传人:zhu****ng 文档编号:164002920 上传时间:2022-10-24 格式:DOC 页数:18 大小:86KB
收藏 版权申诉 举报 下载
C语言程序设计-基于链表的学生成绩管理系统_第1页
第1页 / 共18页
C语言程序设计-基于链表的学生成绩管理系统_第2页
第2页 / 共18页
C语言程序设计-基于链表的学生成绩管理系统_第3页
第3页 / 共18页
资源描述:

《C语言程序设计-基于链表的学生成绩管理系统》由会员分享,可在线阅读,更多相关《C语言程序设计-基于链表的学生成绩管理系统(18页珍藏版)》请在装配图网上搜索。

1、华北科技学院计算机系综合性实验实 验 报 告 课程名称 C语言程序设计 实验学期 2011 至 2012 学年 第 二 学期 学生所在系部 计算机系 年级 2011 专业班级 计算机科学与技术B-111 学生姓名 学号 任课教师 实验成绩 计算机系制实验报告须知1、 学生上交实验报告时,必须为打印稿(A4纸)。页面空间不够,可以顺延。2、 学生应该填写的内容包括:封面相关栏目、实验地点、时间、目的、设备环境、内容、结果及分析等。3、 教师应该填写的内容包括:实验成绩、教师评价等。4、 教师根据本课程的综合性实验指导单中实验内容的要求,评定学生的综合性实验成绩;要求在该课程期末考试前将实验报告交

2、给任课教师。综合性实验中,所涉及的程序,文档等在交实验报告前,拷贝给任课教师。任课教师统一刻录成光盘,与该课程的期末考试成绩一同上交到系里存档。5、 未尽事宜,请参考该课程的实验大纲和教学大纲。C语言程序设计课程综合性实验报告开课实验室:基础五 2012年7月 6 日实验题目基于链表的学生成绩管理系统一、实验目的1、掌握链表的创建、遍历显示和清除; 2、掌握链表数据的文件保存、读取;二、设备与环境 微型计算机、VC+6.0三、实验内容1、定义结构体,创建链表struct xsnode int xh; char xm15; int gs; int yy; int wl; struct xsnod

3、e *next;2、根据以上链表结点结构,实现以下功能 a、学生学号、姓名、各门成绩的录入; b、链表数据显示及清除; c、链表数据的文件保存与读取;四、实验结果及分析1、运行结果主菜单数据显示2、源程序 主函数void main() int xz=0; struct xs *head; head=init(); while(xz!=5) menu(); scanf(%d,&xz); switch(xz) case 1: create(head); break;case 2: print(head); break;case 3: save(head); break; case 4: read(

4、head); break; case 5: printf(n 系统退出,拜拜!n ); break;default:printf(n 选择错误,请按任意键选择!n );getch();break; fr(head); free(head); 数据录入源代码void create(struct xs *hd)int xh,gs,yy,wl,i;char xm20;struct xs *p;fr(hd);printf(n 请输入学生个数:);scanf(%d,&num);for(i=0;ixh=xh;strcpy(p-xm,xm);p-gs=gs;p-yy=yy;p-wl=wl;p-next=hd

5、-next;hd-next=p;printf( 录入数据完毕,请按任意键继续!n );getch();添加记录源代码 void print(struct xs *hd) struct xs*p;p=hd-next;if(p!=NULL)printf(n 数据显示n);printf(*n);printf( 学号 姓名 高数 英语 物理 平均分n);printf(*n);while(p!=NULL)printf(%4d ,p-xh);printf(%10s,p-xm);printf(%8d,p-gs);printf(%7d,p-yy);printf(%6d,p-wl);printf(%8.2fn,

6、(p-wl+p-wl+p-wl)/3.0);p=p-next;printf(*n);printf( 链表显示完毕,请按任意键继续!n); getch();elseprintf(n 当前链表为空,请先读取文件或创建链表!n 按任意键继续!n ); 查询记录源代码void menu()system(cls);printf( *n);printf( * 学生成绩管理系统(1.0) *n);printf( *n);printf( * jb11-1 31 宋洁 2012-7-3 *n);printf( *n);printf( * 1-创建链表 *n);printf( * 2-数据显示 *n);print

7、f( * 3-保存文件 *n);printf( * 4-读取文件 *n);printf( * 5-系统退出 *n);printf( *n);printf( 请选择操作(1-5:); 源程序#includestdio.h#includestdlib.h#include#includeconio.hstruct xsint xh;char xm20;int gs,yy,wl;struct xs *next;int num=0;struct xs *init() struct xs* hd;hd=(struct xs *)malloc(sizeof(struct xs);hd-next=NULL;r

8、eturn hd;void fr(struct xs *hd)struct xs *p; p=hd-next; while(hd-next!=NULL)p=hd-next;hd-next=p-next;free(p);void create(struct xs *hd)int xh,gs,yy,wl,i;char xm20;struct xs *p;fr(hd);printf(n 请输入学生个数:);scanf(%d,&num);for(i=0;ixh=xh;strcpy(p-xm,xm);p-gs=gs;p-yy=yy;p-wl=wl;p-next=hd-next;hd-next=p;pri

9、ntf( 录入数据完毕,请按任意键继续!n );getch();void save(struct xs *hd)if(hd-next!=NULL)struct xs *p=hd-next;int i;FILE *fp;fp=fopen(yh.txt,w);fprintf(fp,%3dn,num);for(i=0;ixh,p-xm,p-gs,p-yy,p-wl);p=p-next;fclose(fp);printf(n 保存文件完毕,请按任意键继续!n );getch();elseprintf(n 当前链表为空,不需要保存,请按任意键继续!n );getch();void read(struct

10、 xs *hd)int i;struct xs *p;FILE *fp;fr(hd);fp=fopen(yh.txt,r);fscanf(fp,%3dn,&num);for(i=0;ixh,p-xm,p-gs,p-yy,p-wl); p-next=hd-next; hd-next=p;fclose(fp);printf(n 读取文件完毕,请按任意键继续!n );getch();void print(struct xs *hd) struct xs*p;p=hd-next;if(p!=NULL)printf(n 数据显示n);printf(*n);printf( 学号 姓名 高数 英语 物理 平

11、均分n);printf(*n);while(p!=NULL)printf(%4d ,p-xh);printf(%10s,p-xm);printf(%8d,p-gs);printf(%7d,p-yy);printf(%6d,p-wl);printf(%8.2fn,(p-wl+p-wl+p-wl)/3.0);p=p-next;printf(*n);printf( 链表显示完毕,请按任意键继续!n); getch();elseprintf(n 当前链表为空,请先读取文件或创建链表!n 按任意键继续!n );void menu()system(cls);printf( *n);printf( * 学生

12、成绩管理系统(1.0) *n);printf( *n);printf( * jb11-1 31 宋洁 2012-7-3 *n);printf( *n);printf( * 1-创建链表 *n);printf( * 2-数据显示 *n);printf( * 3-保存文件 *n);printf( * 4-读取文件 *n);printf( * 5-系统退出 *n);printf( *n);printf( 请选择操作(1-5:); void main()int xz=0; struct xs *head; head=init(); while(xz!=5) menu(); scanf(%d,&xz);

13、 switch(xz) case 1: create(head); break;case 2: print(head); break;case 3: save(head); break; case 4: read(head); break; case 5: printf(n 系统退出,拜拜!n ); break;default:printf(n 选择错误,请按任意键选择!n );getch();break; fr(head); free(head);3、试验收获通过这次试验,我掌握了链表的创建、遍历显示和清除功能,掌握了链表数据的文件保存、读取,能够熟练的使用VC+6.0,对C程序有了更深的了

14、解。教 师 评 价评定项目ABCD评定项目ABCD算法正确界面美观,布局合理程序结构合理操作熟练语法、语义正确解析完整实验结果正确文字流畅报告规范题解正确其他:评价教师签名:年 月 日代码:#includestdio.h#includestdlib.h#include#includeconio.hstruct xsint xh;char xm20;int gs,yy,wl;struct xs *next;int num=0;struct xs *init() struct xs* hd;hd=(struct xs *)malloc(sizeof(struct xs);hd-next=NULL;

15、return hd;void fr(struct xs *hd)struct xs *p; p=hd-next; while(hd-next!=NULL)p=hd-next;hd-next=p-next;free(p);void create(struct xs *hd)int xh,gs,yy,wl,i;char xm20;struct xs *p;fr(hd);printf(n 请输入学生个数:);scanf(%d,&num);for(i=0;ixh=xh;strcpy(p-xm,xm);p-gs=gs;p-yy=yy;p-wl=wl;p-next=hd-next;hd-next=p;pr

16、intf( 录入数据完毕,请按任意键继续!n );getch();void save(struct xs *hd)if(hd-next!=NULL)struct xs *p=hd-next;int i;FILE *fp;fp=fopen(yh.txt,w);fprintf(fp,%3dn,num);for(i=0;ixh,p-xm,p-gs,p-yy,p-wl);p=p-next;fclose(fp);printf(n 保存文件完毕,请按任意键继续!n );getch();elseprintf(n 当前链表为空,不需要保存,请按任意键继续!n );getch();void read(struc

17、t xs *hd)int i;struct xs *p;FILE *fp;fr(hd);fp=fopen(yh.txt,r);fscanf(fp,%3dn,&num);for(i=0;ixh,p-xm,p-gs,p-yy,p-wl); p-next=hd-next; hd-next=p;fclose(fp);printf(n 读取文件完毕,请按任意键继续!n );getch();void print(struct xs *hd) struct xs*p;p=hd-next;if(p!=NULL)printf(n 数据显示n);printf(*n);printf( 学号 姓名 高数 英语 物理

18、平均分n);printf(*n);while(p!=NULL)printf(%4d ,p-xh);printf(%10s,p-xm);printf(%8d,p-gs);printf(%7d,p-yy);printf(%6d,p-wl);printf(%8.2fn,(p-wl+p-wl+p-wl)/3.0);p=p-next;printf(*n);printf( 链表显示完毕,请按任意键继续!n); getch();elseprintf(n 当前链表为空,请先读取文件或创建链表!n 按任意键继续!n );void menu()system(cls);printf( *n);printf( * 学

19、生成绩管理系统(1.0) *n);printf( *n);printf( * jb11-1 31 宋洁 2012-7-3 *n);printf( *n);printf( * 1-创建链表 *n);printf( * 2-数据显示 *n);printf( * 3-保存文件 *n);printf( * 4-读取文件 *n);printf( * 5-系统退出 *n);printf( *n);printf( 请选择操作(1-5:); void main()int xz=0; struct xs *head; head=init(); while(xz!=5) menu(); scanf(%d,&xz); switch(xz) case 1: create(head); break;case 2: print(head); break;case 3: save(head); break; case 4: read(head); break; case 5: printf(n 系统退出,拜拜!n ); break;default:printf(n 选择错误,请按任意键选择!n );getch();break; fr(head); free(head);

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!