版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、数据结构课程设计(学生成绩管理系统)精品文档目录一、运行环境 0一、运行环境 1二、设计目的和意义 12.1 设计目的 12.2 设计意义 1三、算法思想 2四、模块划分 4五、数据结构 5六、程序流程图 6七、程序源代码 9八、程序调试过程分析 19九、测试数据 20十、测试结果及分析 21十一、小结 25参考文献 26收集于网络,如有侵权请联系管理员删除一、运行环境硬件环境:电脑软件环境: vc+6.0二、设计目的和意义2.1 设计目的此次课程设计的目的是让学生在学习完 C、数据结构等课程基础上,进一步掌握 设计、实现较大系统的完整过程,包括系统分析、编码设计、系统集成、以及调试分 析,熟
2、练掌握数据结构的选择、设计、实现以及操作方法,为进一步的应用开发打好 基础。2.2 设计意义此次设计意义在于让我们更好的去掌握 C的基本语法、函数以及 Visual C+ 集 成编译环境。掌握树、图、链表等基本数据结构及其应用。掌握程序流程以及基本应 用方法。应用软件工程方面的知识,熟悉软件开发的流程。通过本课程设计,培养学生进行软件设计能力。首先进行需求分析,针对目标对 象完成程序结构设计、对象设计、主要数据结构设计、输入输出设计、人机界面设计三、算法思想整个系统除了主函数外,另外还有 12 个函数,实现十大功能:菜单选择、输入 功能、显示功能、查找功能、删除功能、排序功能、插入功能、保存功
3、能、读取功 能、修改。各个函数的详细设计说明分别如下:1、主函数 main()利用无限次循环 for(;) 和 swithch() 实现各函数的调用,系统根据输入的数字 选项来调用相应的函数。2、初始化函数 STUDENT *init() 这是一个无参函数,里面只有一个语句,它的作用是使链表初始化 ,使 head的值 为 NULL。比如:没有这个函数的话,在你没有输入任何数据的情况下,去执行显示 功能的时候会显示一些乱码!3、菜单选择函数 int menu_select(); 这是一个无参函数,主要实现“功能选择”的界面,在这个界面里有显示系统的九 大功能,根据每个功能前面的序号进行选择,中间
4、还显示系统当前的时间。等执行完 每一个函数功能后,按任一键回到主界面也要通过这个函数来实现!4、输入记录函数 STUDENT *create() 这是一个无参函数,用来执行第学生成绩记录的输入,当学生为 0 时停止输入, 函数结束后,带回一个指向链表头的指针 head。算法:先声明一个首节点 head,并将 head->next 设为 NULL。每输入一个数据就 声明一个新节点 p,把 p->next 设为 NULL,并且链接到之前列表的尾端。5、显示记录函数 void print(STUDENT *head) 这是一个不返回值的有参函数,形参为“链表头的指针”,负责对全部学生成绩
5、记 录的输出,不足之处就是不能对学生成绩进行分页显示。算法:先将 p结点的指针指向第一个结点,将 p结点(即第一个结点 )的数据输 出。然后再将 p结点的指针指向 p指针的的指针 (即下一结点) ,将p结点(即第一结 点)的数据输出。重复执行此步聚直到 p 指针指向 NULL为止。6、查找记录函数 void search(STUDENT *head) 这是一个不返回值的有参函数,形参为“链表头的指针”,实现按姓名对某个学生 进行查找,并显示所查找到的记录。算法:采用线性查找法往下一个节点查找。输入所要查找的学生的姓名s,设一个指针变量 p,先指向第一个结点,当 strcmp(p->nam
6、e,s) && p != NULL 时,使 p 后移一个结点,如果 p!=NULL,输出 p 所指的结点。7、删除记录函数 STUDENT *delete(STUDENT *head) 这是一个有参函数,形参为“链表头的指针”,先输入要删除的学生记录的学号, 找到后显示该学生信息,等确认后便可按“ Y”进行删除。算法:从 p 指向的第一个结点开始,检查该结点中的 num值是否等于输入的要求 删除的那个学号。如果相等就将该结点删除,如不相等,就将 p 后移一个结点,再如 此进行下去,直到遇到表尾为止。8、排序函数 STUDENT *sort(STUDENT *head) 这是一个
7、有参函数,形参为“链表头的指针”,按学生成绩的平均分高低进行排 序,还可以显示名次。9、修改函数 STUDENT *xiugai(STUDENT *head) 这是一个有参数函数,形参为“链表头的指针”,首先按学生姓名对要修改的学生 记录进行查找,然后对找到的记录进行修改。算法:采用线性查找法往下一个节点查找。输入所要查找的学生的姓名s,设一个指针变量 p,先指向第一个结点,当 strcmp(p->name,s) && p != NULL 时,使 p 后移一个结点,如果 p!=NULL,修改 p 所指的结点的相关记录,修改完成后对记录进 行输出,然后重新调用排序 sort
8、 函数,对新修改的数据进行排序。10、插入函数 STUDENT *insert(STUDENT *head,STUDENT *new)这是一个有参函数,形参有两个,一个是“链表头的指针”,一个是“待插入指 针”,按照原来成绩平均分的高低进行插入,插入后会重新进行排序,并返回。算法:先将学生的成绩按平均分由高分到低分进行排序,再插入一个新生的结点 要求按平均分的高低顺序插入。先用指针变量 p0 指向待插入的结点, p1 指向第一个 结点。如果 p0->average<p1->average ,则待插入的结点不应插在 p1 所指的结点之 前。此时将 p1 后移,并使 p2 指向刚
9、才 p1 所指的结点。重复以上的步骤,直到 p0- >average>=p1->average 为止。这时将 p0 指向的结点插到 p1 所指结点之前。但是如 果 p1 所指的已是表尾结点,则 p1 就不应后移了。如果 p0->average 比所有结点的 average 都小,则应将 p0 所指的结点插到链表末尾。如果插入的位置既不在第一个 结点之前,又不在表尾结点之后,则将 p0 的值赋给 p2-> ,使 p2->next 指向待插入 的结点,然后将 p1 的值赋给 p0->next ,使得 p0->next 指向 p1 指向的变量。如果插
10、入位置为第一个结点之前,则将 p0 赋给 head,将 p1 赋给 p0->next 。如果要插到表 尾之后,应将 p0赋给p1->next ,NULL赋给p0->next 。最后再调用排序的函数 ,将学 生成绩重新排序 .11、保存数据到文件函数 void save(STUDENT *head) 这是一个不返回值的有参函数,形参为“链表头的指针”,可以把学生记录保存在 电脑上由自己任意命名的二进制文件。12、从文件读数据函数 STUDENT *load() 这是一个不返回值的有参函数,形参为“链表头的指针”,根据输入的文件地址进 行读取。四、模块划分学生成绩管理的设计,除了
11、主函数和初始化函数外,主要还设计了十个功能函 数:菜单选择、输入功能、输出功能、查找功能、删除功能、排序功能、插入功能、 保存功能、读取功能、修改函数。通过分组设计现实现部分功能函数说明如下:1、菜单选择: int menu_select();提供十种可以选择的操作,在 main 函数中通过 switch 语句调用菜单 menu_select() 函数,进入不同的功能函数中完成相关操作。2、输入功能: STUDENT *create();通过一个 for 循环语句的控制,可以一次完成无数条记录的输入。并将其存入链 表。3、输出功能: void print(STUDENT *head);通过一个
12、 while 的循环控制语句,在指针 p!=0 时,完成全部学生记录的显示。 知道不满足循环语句,程序再次回到菜单选择功能界面。4、查找功能: void search(STUDENT *head);通过 strcmp 来判断是否找到所需查找的学生记录,在不满足该条件时,通过 while 语句完成结点的下移,最后若查找成功则完成显示。返回主菜单界面。5、删除功能: STUDENT *Delete(STUDENT *head);按想要删除的学生的学号首先进行查找,通过指针所指向结点的下移来完成, 如果找到该记录,则完成前后结点的连接,同时对以查找到的结点进行空间的释放, 最后完成对某个学生记录进行
13、删除,并重新存储。6、修改功能: STUDENT *xiugai(STUDENT *head);首先通过想核对想要修改的学生姓名进行查到,相当于调用一次查找函数 search, 如果查找成功则对数据进行修改,最后计算其总分和平均分,调用一次排序 函数 sort, 重新进行排序,并重新存储记录。五、数据结构定义了一个 typedef struct stu的结构体数组,相关描述如下:#define LEN sizeof(STUDENT)typedef struct stu /* 定义结构体数组用于缓存数据 */ char num6;char name20;int score3;int sum;fl
14、oat average;int order;struct stu *next; STUDENT;六、程序流程图61、程序的总体模块流程图如下:读写文件对学生成绩进行排序查询学生记录删除学生记录插入学生记录修改学生记录输出学生记录输入学生记录退出图 6-162、删除学生记录流程图如下:图 6-26.3 、插入学生记录流程图如下:七、程序源代码#include <stdio.h> #include<dos.h> #include<stdlib.h> /* #include<string.h> /* #include<ctype.h> /*
15、 #define LEN sizeof(STUDENT) typedef struct stu /* 其它说明 */字符串函数 */字符操作函数 */定义结构体数组用于缓存数据 */初始化函数 */菜单函数 */创建链表 */显示全部记录 */查找记录 */* 删除记录 */* 排序 */char num6;char name20; int score3;int sum; float average;int order; struct stu *next; STUDENT;/* 函数原型 */STUDENT *init(); /* int menu_select(); /*STUDENT *c
16、reate(); /* void print(STUDENT *head); /* void search(STUDENT *head);/*STUDENT *Delete(STUDENT *head); STUDENT *sort(STUDENT *head);STUDENT *insert(STUDENT *head,STUDENT *New); /* 插入记录 */STUDENT *xiugai(STUDENT *head); /* 修改记录 */ void save(STUDENT *head); /* 保存文件 */读文件 */链表初始化 ,使 head的值为 NULL*/循环无限次
17、 */STUDENT *load();/*/* 主函数界面 */ void main()STUDENT *head,New; head=init(); /* for(;) /* switch(menu_select()case 1:head=create();break;case 2:print(head);break;case 3:search(head);break;case 4:head=Delete(head);break;case 5:head=sort(head);break;case 6:head=insert(head,&New);break; /*&new 表
18、示返回地址 */case 7:save(head);break;case 8:head=load(); break;case 9:xiugai(head);break;case 10:exit(0); /* 如菜单返回值为 9 则程序结束 */* 初始化函数 */STUDENT *init()return NULL; /*/* 菜单选择函数 */返回空指针 */menu_select()int n;printf("*n");printf("tt Welcome ton"); printf("ntt The student score manag
19、e systemn");printf("ttt1.输入学生记录 n");/*输入学生成绩记录 */printf("ttt2.输出学生记录 n");/*显示*/printf("ttt3.查找学生记录 n");/*寻找*/printf("ttt4.删除学生记录 n");/*删除*/printf("ttt5.将学生成绩进行排序 n");/*排序*/printf("ttt6.插入一个新的学生记录n");/*插入*/printf("ttt7.保存记录 n"
20、);/*保存*/printf("ttt8.读取记录 n");/*读取*/printf("ttt9.修改记录 n");/*修改 */printf("ttt10.退出n");/*退出*/printf("*MENU*n");printf("ntt 夏翠玉、陈洁丽 .n");printf("*n");doprintf("nttt输入您的选择 (110):");scanf("%d",&n);如果选择项不在 19 之间则重输 */while
21、(n<1|n>10); /* return(n); /* 返回选择项,主函数根据该数调用相应的函数*/* 输入函数 */STUDENT *create()int i,s,k;int j=0;STUDENT *head=NULL,*p; /* 定义函数 . 此函数带回一个指向链表头的指针 */ system("cls");printf("n 请输入您想输入的学生个数: ");scanf("%d",&k);for(j=0;j<k;j+)p=(STUDENT *)malloc(LEN); /* 开辟一个新的单元 *
22、/if(!p) /*如果指针 p 为空*/printf("n 输出内存溢出 ."); /* 输出内存溢出 */return (head); /*返回头指针 , 下同 */printf(" 输入学号 (0:list end):");scanf("%s",p->num);if(p->num0='0') break;/* 如果学号首字符为 0 则结束输入 */printf(" 输入姓名 :");scanf("%s",p->name);printf(" 请分别
23、输入语文、数学、英语的分数 %d scoresn",3);/* 开始输入 */ s=0; /* 计算每个学生的总分,初值为 0*/ for(i=0;i<3;i+) /*3门课程循环 3 次*/doprintf("score%d:",i+1);scanf("%d",&p->scorei);if(p->scorei<0 | p->scorei>100) /* 之间 */printf("Data error,please enter again.n");while(p->score
24、i<0 | p->scorei>100); s=s+p->scorei; /* 累加各门成绩 */ p->sum=s; /*将总分保存 */确保成绩在 0100p->average=(float)s/3;/* 先用强制类型转换将 s 转换成 float 型, 再求平均值*/p->order=0; /* p->next=head; /* head=p; /*未排序前此值为 0*/ 将头结点做为新输入结点的后继结点 */ 新输入结点为新的头结点 */ return(head);/* 显示全部记录函数 */void print(STUDENT *hea
25、d)STUDENT *p; /* 移动指针 */ system("cls");p=head; /* 初值为头指针 */printf("n*STUDENT*n");printf("n");printf("| 学号 | 姓名 | 语文 | 数学 | 英语 | 总分 | 平均 成绩 | 名次 |n");printf("n");while(p!=NULL)printf("| %4s | %-4s | %3d | %3d | %3d| %3d | %4.2f | %-5d|n",p-&
26、gt;num,p->name,p->score0,p->score1,p->score2,p->sum,p->average,p->order);p=p->next;printf("n");printf("*END*n");/* 查找记录函数 */void search(STUDENT *head)STUDENT *p;/* 移动指针 */char s5;/* 存放姓名用的字符数组 */system("cls");printf(" 请输入查找者姓名 .n");scan
27、f("%s",s);p=head; /* 将头指针赋给 p*/while(strcmp(p->name,s) && p != NULL) /* 当记录的姓名不是要找的, 或指针不为空时 */p=p->next; /* 移动指针,指向下一结点 */if(p!=NULL) /* 如果指针不为空 */printf("n*FOUND*n");printf("n");printf("| 学号 | 姓名 | 语文 | 数学 | 英语 | 总分 | 平均成 绩 | 名次 |n");printf(&qu
28、ot;n");printf("| %4s | %4s | %3d | %3d | %3d | %3d| %4.2f | %-5d|n", p->num,p->name,p->score0,p->score1,p- >score2,p->sum,p->average,p->order);printf("n");printf("*END*n");显示没有该学生 */ elseprintf("n无此记录 .n",s);/*/* 删除记录函数 */STUDENT *
29、Delete(STUDENT *head)STUDENT *p1,*p2; /*p1 为查找到要删除的结点指针, p2 为其前驱指针 */ char c,s6; /*s6 用来存放学号 ,c 用来输入字母 */ system("cls");printf(" 请输入要删除的学生的学号 : ");scanf("%s",s);p1=p2=head; /*给p1和p2赋初值头指针 */while(strcmp(p1->num,s) && p1 != NULL) /* 当记录的学号不 是要找的,或指针不为空时 */p2=p
30、1; /*将p1指针值赋给 p2作为 p1的前驱指针 */p1=p1->next; /*将 p1 指针指向下一条记录 */if(strcmp(p1->num,s)=0) /*学号找到了 */printf("* *FOUND*n");prin");printf("| 学号 | 姓名 | 语文 | 数学 | 英语 | 总分 | 平均成绩 | 名次 |n");printf("n");printf("| %4s | %4s | %3d | %3d | %3d | %3d| %4.2f | %-5d|n"
31、;, p1->num,p1->name,p1->score0,p1->score1,p1->score2,p1->sum,p1- >average,p1->order);n");printf(" printf("*END*如果不删除 , 则跳出本循环 */若 p1=head,说明被删结点是首结点 */把第二个结点地址赋予 head*/printf(" 您确定要删除该学生的记录吗 Y/N ?"); /* 提示是否要删除 , 输入 Y删除,N 则退出*/for(;)scanf("%c&quo
32、t;,&c); if(c='n'|c='N') break; /* if(c='y'|c='Y')if(p1=head) /* head=p1->next; /* elsep2->next=p1->next;free(p1);/* 否则将一下结点地址赋给前一结点地址 */printf("n 学号为 %s 的学生记录已被删除 .n",s);printf(" 别忘了重新存储记录 .n");break; /*删除后就跳出循环*/elseprintf("n 找不到
33、学号为 %s 的学生记录 .n",s); /*找不到该结点*/return(head);/* 修改函数 */STUDENT *xiugai(STUDENT *head)STUDENT *q; /* 移动指针 */char s5; /* 存放姓名用的字符数组 */system("cls");printf(" 请输入查找者姓名 .n");scanf("%s",s);q=head; /* 将头指针赋给 p*/while(strcmp(q->name,s) && q != NULL) /* 当记录的姓名不是要找
34、的, 或指针不为空时 */q=q->next; /* 移动指针,指向下一结点 */if(q!=NULL) /* 如果指针不为空 */printf("n*FOUND*n");int sum1,i;printf("n 请在下面输入要修改成的学生的记录 .n"); /* 提示输入 记录信息 */printf(" 学号 :"); scanf("%s",q->num);printf(" 姓名 :");scanf("%s",q->name);printf("
35、分别输入 %d 科的分数 .n",3);sum1=0; /* 保存新记录的总分,初值为 0*/ for(i=0;i<3;i+)doprintf("score%d:",i+1); scanf("%d",&q->scorei); if(q->scorei>100|q->scorei<0) printf("Data error,please enter again.n");while(q->scorei>100|q->scorei<0); sum1=sum1+q-
36、>scorei; /* 累加各门成绩 */ q->sum=sum1;q->average=(float)sum1/3;q->order=0;printf("n");printf("| 学号 | 姓名 | 语文 | 数学 | 英语 | 总分 | 平均成 绩 | 名次 |n");printf("n");printf("| %4s | %4s | %3d | %3d | %3d | %3d | %4.2f | %-5d|n",q->num,q->name,q->score0,q-
37、>score1,q->score2,q->sum,q->average,q- >order);printf("n");printf("*END*n");head=sort(head); /*调用排序的函数 , 将学生成绩重新排序 */printf("n 学生 %s 已经修改成功 .n",q->name); printf(" 请别忘了重新存储 .n");elseprintf("n 无此记录 .n",s); /* 显示没有该学生 */return(head);八、
38、程序调试过程分析(1)刚开始没有那个初始化函数,程序运行后,没有输入任何数据就试得去执 行显示功能,结果显示的是一些乱码!加入初始化函数后,这种现象也随之消失。(2)刚开始执行输入函数,按学号顺序输入十个学生的成绩 , 输完后执行显示功 能,学生成绩记录是按学号的反顺序显示的,试着在其中增加一些语句,希望能把学 号按正常顺序显示,但暂时没有成功,所以在输入成绩时只能按学号反顺序输入,最 后就按学号正常顺序输出了。(3)刚开始时,先把成绩按平均分排序,再插入一个学生的成绩,执行显示功 能,虽然插入的学生的成绩能正常插入,但该学生的名次为 0。后来,在插入成绩之 后,调用排序函数,把所有成绩重新排
39、序一次。(4)在输入函数中设了一个无限循环,可以输入无数个学生的成绩信息,当学 号为 0 的时候则停止输入。(5)输入太多个学生的成绩时,屏幕显示不能控制为一页一页显示,所以为了 方便起见,不要输入太多记录,十七左右为最佳。(6)在没有输入任何信息的情况下,去执行排序功能,最后显示有一个记录, 学号、姓名为空白,成绩都为 0,名次为 1。(7)在输入选项时不能输入字母 , 否则会死循环,建议不要乱输字母。(8)在编写修改函数时,发现平均成绩和总成绩没有变化,原因为循环语句之后 没有进行数据的重新赋值,以至于新的数据没能插进链表。九、测试数据下面对所设计系统进行数据测试:1、在主菜单选择 1、输入学生记录,分别输入三组学生记录为:学号姓名语文成绩数学成绩英语成绩1Xai4556662Cui5644563yu4566772、在主菜单选择 6、插入一个新的学生记录,插入数据为: 学号 4 姓名 Gu 语文成绩 45 数学成绩 44 英语成绩 333、在主菜单选择 9、修改记录,修改
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年汽车修理厂综合维修工职业协议样本版B版
- 2024年黄金产品销售代表合同版B版
- 2025年度智能工厂产权转让及定金支付协议范本3篇
- 2024年度大蒜种植补贴项目采购合同2篇
- 2024年环保设施运营管理服务合同
- 危重心律失常的急诊处理
- 2025年度科幻小说改编剧本创作合同3篇
- 2024版自建房房屋买卖合同
- 2024年规范保健品购销合同模板版B版
- 2024年物业管理分包协议6篇
- 汽车内饰件及材料气味评价标准解析
- 幕墙工程售后服务流程及保修维修措施方案
- 夫妻间经济合同模板
- 2023-2024学年上海市静安区继续教育学校附属学校八年级(上)期末物理试卷
- 人教版五年级上册四则混合运算300道及答案
- 服装企业员工手册模板范文
- 《低空航空器起降点基础设施配置技术要求》(征求意见稿)
- 2024中轻度游戏全球市场趋势洞察
- 中国儿童注意缺陷多动障碍ADHD防治指南专家讲座
- 部编人教版数学二年级下册课前预习单
- 解除劳动合同经济补偿协议书
评论
0/150
提交评论