学生成绩管理系统课程设计报告c++.doc_第1页
学生成绩管理系统课程设计报告c++.doc_第2页
学生成绩管理系统课程设计报告c++.doc_第3页
学生成绩管理系统课程设计报告c++.doc_第4页
学生成绩管理系统课程设计报告c++.doc_第5页
免费预览已结束,剩余5页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

学生成绩管理系统课程设计报告前言一、系统的设计需求1、整个系统均用C语言实现;2、利用指针、链表来实现学生成绩的数据结构设计;3、系统具有输入、显示、删除、排序、退出基本功能;4、系统的各个功能模块都用函数的形式来实现;5、可以将学生信息全部显示出来出来。二、系统的功能模块划分每一条记录包括一个学生的姓名、成绩。同时1、输入功能:一次可以完成一个学生成绩记录的输入。2、显示功能:完成全部学生记录的显示。3、删除功能:对指定学生的成绩进行删除。4、排序功能:按学生从大到小进行排序。5、修改功能:对学生的成绩进行修改。三、系统的整体设计1.数据结构设计:A、输入功能的设计:void insert_func(void) char s_temp4;ptr=(struct student *) malloc(sizeof(struct student);printf( Student name : );gets(ptr-name);/ gets从标准输入设备读取字符串/printf( Student score: );gets(s_temp);ptr-score = atoi(s_temp);/把字符串转化为 整数/B、删除功能的设计:void delete_func(void)/现在进入删除操作/char del_name20;printf( Delete student name: );gets(del_name);prev = head;current = head-next;while (current != NULL) & (strcmp(current-name , del_name)!=0)/用到了strcmp 比较字符串prev = current;current = current-next;if (current != NULL)prev-next = current-next;free(current);/释放当前位置/printf( %s student record deletedn,del_name);/输出被删除的姓名/elseprintf( Student %s not foundn,del_name);/否则此学生不存在/C、排序功能的设计:void sort_func(void) /插入数据/prev = head;/把头指针所指的值付给prev/current = head-next;/把头指针的下一个指针值付给当前指针所指的位置/while (current != NULL) & (current-score ptr-score)prev = current;current = current-next;ptr-next = current;prev-next = ptr;D、修改功能的设计:void modify_func(void)char n_temp20,s_temp4;/定义字符类型/printf( Modify student name: );gets(n_temp);/这样输入姓名current=head-next;while (current != NULL) & (strcmp(current-name , n_temp)!=0)prev = current;current = current-next;if (current != NULL)printf( *n);printf( Student name : %sn,current-name);printf( Student score: %dn,current-score);printf( *n);printf( Please enter new score: );gets(s_temp);current-score = atoi(s_temp);printf( %s student record modifiedn,n_temp);/输出被修改的成绩/elseprintf( Student %s not foundn,n_temp);/否则此学生不存在/anykey_func();E、显示功能的设计:void display_func(void)/定义显示/int count=0;system(cls);if(head-next = NULL)/如果头指针所指数为空/printf( No student recordn);/则输出学生记录为空/else/否则输出学生姓名和成绩/printf( NAME SCOREn);printf( -n);current=head-next;while(current != NULL)printf( %-20s %3dn, current-name, current-score);count+;current=current-next;if(count % 20 = 0) getch();printf( -n);printf( Total %d record(s) foundn, count);2.功能模块的具体设计整个系统除了主函数外,另外还有8个函数,实现5大功能:输入功能、显示功能、排序功能、删除功能、修改功能。各个函数的详细设计说明分别如下:1、 主函数 main()利用while()循环和swithch()实现各函数的调用,系统根据输入的数字选项来调用相应的函数。2、 输入记录函数getch(); insert_func();这是一个无参函数,用来执行第学生成绩记录的输入,当当没有学生纪录时就开始进行输入操作。算法:先声明一个首节点head,并将head-next设为NULL。然后用 if(fptr=fopen(“slist.dat”,”r”)=NULL)对程序进行判断如果成立则进行输入,输入时运用getch()函数和insert_func()主导来完成。 最终效果图:3、 显示记录函数 void display_func(void)这是一个不返回值的有参函数,负责对全部学生成绩记录的输出,不足之处就是不能对学生成绩进行分页显示。算法: 先用if语句对头指针的下一给位置进行判断看是否为空如果为空则不显示如果不为空则输出学生姓名及成绩。算法:现将head-next赋值给当前位置current然后再用while对current进行定义最后输出。 最终效果:4、 删除记录函数void delete_func(void)这是一个有参函数,先输入要删除的学生记录的 姓名,找到后显示该学生信息,等确认后便可进行删除。算法:从p指向的第一个结点开始,检查该结点中的num值是否等于输入的要求删除的那个姓名。如果相等就将该结点删除,如不相等,就将p后移一个结点,再如此进行下去,直到遇到表尾为止。最终效果:5、排序函数void sort_func(void)这是一个有参函数,按学生成绩的大小进行排6、修改函数 void modify_func(void)这是一个有参函数,先输入要修改的学生姓名找到后对其成绩进行修改。算法:先将head-next赋值给当前位置current然后用while函数对其进行定义然后检查该节点中的姓名是不是p要找的如果相等就修改,如不相等,就将current next赋值给current在于p节点比较直到遇到表尾为止。五、调试分析(1)刚开始没有那个初始化函数,程序运行后,没有输入任何数据就试得去执行显示功能,结果显示的是一些乱码!加入初始化函数后,这种现象也随之消失。(2)刚开始执行输入函数,输入十个学生的成绩,输完后执行显示功能,学生成绩记录是按输入时的顺序显示的,试着在其中增加一些语句,希望能把学号按从大到小的顺序显示,但暂时没有成功,但最后还是按从大到小的顺序输出了。(3)在输入函数中设了一个无限循环,可以输入无数个学生的成绩信息,但最后失败了只能一个一个输入。(4)输入太多个学生的成绩时,屏幕显示不能控制为一页一页显示,所以为了方便起见,不要输入太多记录,十七左右为最佳。六、总结经过一个多星期的C语言课程设计,感觉自己收获不少!首先是:链表本来上课是没有上的,但这个课程设计里面主要都是用链表,因为要达到这样的功能,使用链表相当方便,但不容易理解,所以在这方面我花了很多的时间看课本和参考课外书,使C语言的知识强化了不少。其次,在做课程设计的过程中,发现了平时很多没有注意到的问题,例如:返回值函数和不返回值函数两者在主函数中的调用是不同的,这些内容虽然老师上课都讲过但没好好听加上时间长忘了不少但经过这次课程设计我对他们熟悉了很多更重要的是,这次课程设计虽然花了我不少时间,但正是这些时间,让我见识到了C语言的重要性。这个学生成绩管理系统都是在自己知识范围内完成的,所以界面清晰简单,可能不是很好看,但绝对实用!从这里我也得到一个体会,做一个程序,或者开发一个软件,应该着重从它的后台制作入手,不能做出一个中看不中用的程序或者软件。相信这次的课程设计为我以后继续从事计算机工作打了一个小小的开头。由于这是第一次进行设计,写文档,难免会写得不好!希望老师不要嫌少。附件:代码如下/* file name: slist.c */* 单向键结链表,插入、删除使用排序 */学会对文件操作文件操作和单链表一起使用#include #include #include #include void read_func(void);void write_func(void);void insert_func(void);void sort_func(void);/ sort意思为类型/void delete_func(void);void display_func(void);void modify_func(void);void anykey_func(void);struct studentchar name20;int score;struct student *next;struct student *ptr, *head, *current, *prev;/全部声明为全局变量int main(void)char option1;system(cls);/清屏read_func();/func意思为目前使用者定义函式的参数列的数目/while(1)printf(*n);printf( 1.插入n);printf( 2.删除n);printf( 3.显示n);printf( 4.修改n);printf( 5.退出n);printf(*n);printf( Please enter your choice (1-5).);option1=getche();printf(n);switch(option1)case 1:insert_func();break;case 2:delete_func();break;case 3:display_func();break;case 4:modify_func();break;case 5:/ write_func();/写入参数数目/exit(0);/这里也处理的比较好void read_func(void)FILE *fptr;/ FILE意思为归档/head=(struct student *) malloc(sizeof(struct student);head-next = NULL;/* 开始时,若表中不存在数据,则要求输入第一笔数据 */if(fptr=fopen(slist.dat,r) = NULL)printf( Data file not existn);/数据文件不存在/printf( Press any key to edit first record.n);getch();/字符插入函数/insert_func();/不存在就实行插入操作elseptr=(struct student *) malloc(sizeof(struct student);while(fscanf(fptr, %s %d, ptr-name, &ptr-score) != EOF)sort_func();ptr=(struct student *) malloc(sizeof(struct student);fclose(fptr);/关闭fptr所指的文件释放缓冲区/void write_func(void)FILE *fptr;fptr=fopen(slist.dat,w);current=head-next;/ current意思为当前的/while(current != NULL)fprintf(fptr, %s %dn, current-name, current-score);current = current-next;fclose(fptr);void insert_func(void) /一插入就比较字符串(想比较很简单) 不是等到全部插完了才比较char s_temp4;ptr=(struct student *) malloc(sizeof(struct student);printf( Student name : );gets(ptr-name);/ gets从标准输入设备读取字符串/printf( Student score: );gets(s_temp);ptr-score = atoi(s_temp);/把字符串转化为 整数/sort_func();/*以分数高低由大到小排列*/void sort_func(void) /插入数据/prev = head;/把头指针所指的值付给prev/current = head-next;/把头指针的下一个指针值付给当前指针所指的位置/while (current != NULL) & (current-score ptr-score)prev = current;current = current-next;ptr-next = current;prev-next = ptr;/前面是进行成绩排序操作/void delete_func(void)/现在进入删除操作/char del_name20;printf( Delete student name: );gets(del_name);prev = head;current = head-next;while (current != NULL) & (strcmp(current-name , del_name)!=0)/用到了strcmp 比较字符串prev = current;current = current-next;if (current != NULL)prev-next = current-next;free(current);/释放当前位置/printf( %s student record deletedn,del_name);/输出被删除的姓名/elseprintf( Student %s not foundn,del_name);/否则此学生不存在/以上为删除操作/anykey_func();/进入修改操作/void modify_func(void)char n_temp20,s_temp4;/定义字符类型/printf( Modify student name: );gets(n_temp);/这样输入姓名current=head-next;while (current != NULL) & (strcmp(current-name , n_temp)!=0)prev = current;current = current-next;if (current != NULL)printf( *n);printf( Student name : %sn,current-na

温馨提示

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

评论

0/150

提交评论