C语言课程设计说明书.doc_第1页
C语言课程设计说明书.doc_第2页
C语言课程设计说明书.doc_第3页
C语言课程设计说明书.doc_第4页
C语言课程设计说明书.doc_第5页
免费预览已结束,剩余31页可下载查看

下载本文档

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

文档简介

佛山科学技术学院课程设计说明书设计名称:C语言课程设计题目:学生成绩管理系统姓名:XXX专业:网络工程班级:08级1班学号:XXXXXXX指导老师:周燕日期:2010年3月9日课程设计任务书 专业 年级 班 一、 设计题目二、 学生成绩管理系统三、 主要内容数据库的数据项主要数据包括:学号、姓名、年级、专业、成绩1、成绩2、成绩3、平均成绩、总成绩。要求具有以下功能:(1)系统以菜单方式工作。v(2)显示、保存记录;添加、删除、修改任意个记录。(3)排序功能:打开学生数据库,计算每个学生的平均成绩和总成绩,用冒泡法或选择排序法将平均成绩和总成绩排序后生成两个新文件(从大到小),存盘并显示这两个文件的全部记录。(4)查询功能:打开总成绩排序文件,用折半查找法统计出给定分数的人数并显示。并能按学号或姓名查找并显示某个学生的各科成绩。(5)统计功能:对各科成绩统计分析(平均分、最高分、最低分、及格率等);统计各科各分数段人数。 四、 具体要求围绕课程设计的目的和意义,基本要求如下:1、认真阅读C语言课程设计指导书,明确课程设计的目的、意义和要求;2、快速总结C程序设计语言的精髓,如:函数的概念、函数的设计和函数的调用;3、快速熟悉Tuber C 或C+的上机环境。能熟练进行高级编辑操作(特别是字块操作);熟悉步进式、断点跟踪的程序调试方法,提高工作效率。4、根据“课程设计题目”,采用结构化的程序设计思想,确定系统的总体设计方案、确定时间进度。如果是多人共一题,则要首先完成小组内的人员分工及安排,不允许重题现象。5学习并了解良好的程序设计风格。按质、按量、并按时间完成课程设计的任务。6提供可运行的课程设计系统,参加上机面试答辩。本次课程设计的重点是:学会设计并编写函数,掌握好各函数之间的调用关系;利用文件操作函数,建立数据库并完成对数据库的各种操作;掌握几种典型算法的应用(如:冒泡法、选择排序法和折半查找法)。同时锻炼学生根据题目进行分析、设计、编码、调试程序和书写必要文档的综合处理能力,从实践中学习并体会程序设计的结构化思想和设计方法。五、 进度安排依照教学计划,课程设计时间为3周。按照软件工程的思想,软件系统的分析设计至关重要,并要充分重视书写“文档”。避免甚至杜绝“拿到题目就编码”的现象。建议将时间分为三个阶段:第一阶段,根据题目要求,拿出系统的总体设计方案:即构思各程序模块的算法,并画出相应的N-S图,同时编写相应的文档;第二阶段,根据N-S图编写程序代码并单独调试,再将调试通过的各个子模块进行集成调试;第三阶段,归纳文档资料,按要求填写在课程设计说明书上,并参加答辩。三个阶段时间分配的大概比例是: 35:45:20。六、 完成后应上交的材料1课程设计的题目、系统的总功能和各子模块的功能;2题目的设计思想(或算法)简述;3主要程序的框图(要求用N-S图);4源程序代码(要求在关键的位置有注释,从而增加程序的可读性);5课程设计的总结报告,主要包括以下内容:(1)课程设计中遇到的主要问题和解决方法;(2)你的创新和得意之处;(3)设计中存在的不足及改进的设想;(4)本次课程设计的感想和心得体会。以上完成的源程序及相关文档,填写在课程设计说明书上,要求干净整洁,符合课程设计的要求和规范。七、 总评成绩指导教师 签名日期 年 月 日系 主 任 审核日期 年 月 日C语言程序设计目录一、系统功能2二、功能模块的描述31.数据结构32.main()主函数43. Pwd();/密码验证函数44 student *creat(void)创建动态链表55print(struct student *head)输出链表66DelMain(struct student *head)/删除判断函数67student *del(struct student *head,long num)删除记录78InputMain(struct student *head)/插入判断函数89student *insert(struct student *head,struct student *stud)插入记录810. Correct(struct student *head);/继续修改判断函数911Save()保存记录到文件函数:(源程序P24)1012Read()从文件中读取记录函数:1113. ReadStuAllToPao()读取保存的数据,冒泡排序后输出到屏幕并放到stuPao.dat文件1114. ReadStuAllToSel()读取保存的数据,选择排序后输出到屏幕并放到stuSel.dat文件1215ReadPao(),ReadSel(),分别从stuPao.dat和stuSel文件中读取记录函数1316. Binsrch()二分法查找总分人数1317StaScore()分析统计函数:14三、源程序15四、课程设计总结331、设计过程的感受与体会332、遇到的问题与解决方法33一、系统功能1、系统需求分析学生的成绩是一个庞大的数量,人工处理起来是一件吃力,繁琐的工作。本系统的设计只要是为了减轻教师们的负担,使其能方面,快捷地对学生的成绩进行查找,修改,分析处理。2、系统功能分析 本系统的功能包括了密码验证功能,录入、输出学生成绩功能,对成绩进行增、删、改的功能,保存进文件、读取文件的功能,根据平均分排序,根据总成绩查找人数的功能,对各科成绩进行分析统计的功能。 3、系统总框架主程序密码进入菜单判断数据输入显示信息添加信息删除信息修改信息冒泡排序选择排序人数查找统计分拆退出按任意键返回二、功能模块的描述1.数据结构学生信息包括学号、姓名、年级、专业、成绩1、成绩2、成绩3、平均成绩、总成绩。所以将其定义为结构体。本系统使用链表对数据进行添、删、改,然后把数据赋给结构体,以结构体的形式保存进文件。结构体说的定义如下:struct studentlong num;/记录学号char name10;/记录姓名char grade10;/记录年级char specialty10;/记录专业float score3;/记录三科成绩分数float avg;/记录平均分float sum;/记录总成绩struct student *next;/指向下一结点的指针stud100; 2.main()主函数程序采用模块化设计,主函数是程序的入口,各模块独立,可分块调整,均由主函数控制。采用do-while死循环和switch分支语句编写菜单选择控制各个模块的功能,每个模块的功能由简单的基本函数构成。直接利用输出函数printf输出字符串,在屏幕上显示一个菜单,并显示一个提示输入选项,输入09之间的数字,将此数字作为菜单函数的返回值返回主函数,主函数根据这个数字调用相应的功能函数,制作简便,操作简单。用printf显示菜单输入菜单选项序号赋给C 判断数否输入有错误 是 否提示输入超出范围进行菜单功能的选择当C超出菜单范围返回C值3. Pwd();/密码验证函数 本系统提供密码功能,密码初始化为“000000”,并提供密码屏蔽功能。密码验证函数的具体做法是,先接收一段字符,然后看与系统预先设定的密码字符串是否相同,如果相同则返回1,不相同则重新接收一串字符,重复三次,自动返回0. For i=0 to 2 For i=0 to 6 pwdPuti = getch()单个输入密码输出“*”判断密码是否正确否 是返回1 返回04 student *creat(void)创建动态链表为了输入时不出错,输入方法使用一个数据一行的方式输入,用回车确定。考虑到学生的学号不可能为0,所以当输入的学号数为0时,把表尾结点的指针变量置NULL。由于记录并不是一次性全部输入,而是随时添加和删除的,而预先开辟的空间数往往大于实际的记录数,所以程序设定全局变量n,随时记录所输入学生个数。当输入结束后,调用save()函数保存数据。开辟一个新结点,并使p1p2指向它读入一个学生数据给p1所指向的结点head = null,n = 0n= n + 1 n等于1?真 假把p1所指的结点作为第一个结点把p1所指的结占连接到表尾 p2移到表尾再开辟一个新结点,使p1指向它读入一个学生数据给p1所指结点当读入的p1- num 不是零表尾结点的指针变量置NULL 调用save()函数保存5print(struct student *head)输出链表 传进去head的地址,然后设一个指针变量p,先指向第一个结点,输出p所指的结点,然后使p后移一个结点,再输出,直到链表的尾结点。为了保存数据,在输出的同时把该链表的值赋给结构体变量stud,其中,字符串用strcpy()来赋值。再使用Avg()和Sum()函数来计算学生的平均分和总分。P = head,使p指向第一个结点 P指向的不是尾结点 真 假输出p所指向的结点P指向下一个结点把链表的值赋给stud当p指向的不是表尾使用Avg()和Sum()计算学生的平均分和总分6DelMain(struct student *head)/删除判断函数 此函数用一个循环来判断是否继续删除结点,当输入学号为0时,循环结束,保存数据。输入要删除的学号学号不等于0调用del()删除结点,并输出继续输入要删除的学号调用Save()保存7student *del(struct student *head,long num)删除记录 输入要删除记录的学号,从p指向的第一个结点开始,检查结点中的num值是否等于输入的要求删除的那个学号。如果相等就将该结点删除,如果不相等,就将p后移一个结点,再如此进行下去,直到遇到表尾为止。若遇到空链表或找不到要删除的结点,输出信息。YES链表是一个空表NO输出“空表”p1 = head 当num 不等于p1-num以及p1所指的结点不是表表尾结点p2后移一个位置p1后移一个位置 p1是要删除的结点 是 否 p1所指是头结点是 否输出“找不到”的信息head = p1-next删除头结点n = n - 1P2-next = p1-next删除一个结点n = n - 18InputMain(struct student *head)/插入判断函数 此函数用一个循环来判断是否继续插入结点,当输入学号为0时,循环结束,保存数据。输入要插入的学号学号不等于0调用insert()插入结点,并输出继续输入要插入的学号调用Save()保存9student *insert(struct student *head,struct student *stud)插入记录 输入要删除记录的学号,从p指向的第一个结点开始,检查结点中的num值是否等于输入的要求删除的那个学号。如果相等就将该结点删除,如果不相等,就将p后移一个结点,再如此进行下去,直到遇到表尾为止。若遇到空链表或找不到要删除的结点,输出信息。p1 = head,p0 = stud原来的链表是一个空表YES NO将p0所指的结点作为唯一结点当p0-num p1-num以及p1所指的不是表尾结点 p2后移一个位置p1后移一个位置 p0-num num 是 否 p1所指是头结点是 否插到表尾之后Head = p0p0-next = p1插到表头之前p2-next = p0p0-next = p1插到表中间 n = n + 110. Correct(struct student *head);/继续修改判断函数 此函数以调用删除函数和插入函数来对学生信息进行修改。首先输入要修改的学号,用del()函数来删除些学号的信息,再用insert()来重新输入刚才那学号对应的信息。输入要修改的学号学号不等于0调用del(head)删除结点,并输出调用insert(head,stu)为刚才的学号插入新数据继续输入要修改的学号调用Save()保存11Save()保存记录到文件函数: 在程序中的数据输入和输出是以终端为对象的,当程序关闭后,数据也就丢失了,所以为了能随时查阅数据,必须将数据输出到磁盘文件上保存起来,使用时人磁盘中读入到内存中,这就用到了磁盘文件的读写操作。按照文件的读写要求,先定义一个指向文件的指针,按W写的方式打开stuAll.dat文件,保存进文件中,如果文件不存在则系统自动创建文件。如果文件不能正常打开,则输出信息;否则,先写入数n,然后用循环语句,用文件格式输出语句fwrite(&studi,sizeof(struct student),1,fp);逐条写入记录,提示保存成功,最后关闭文件。 fp=fopen(“stuAll.dat”,”w”)为输出打开一个文件 打开是否成功否 是输出提示不能打开文件返回将数据写入stuAll.dat文件For i=0 to n-1格式写入记录fwrite(&studi,sizeof(struct student),1,fp)提示保存成功fclose(fp);关闭文件12Read()从文件中读取记录函数: 数据一但写出保存到磁盘中后,更多的操作是将数据从文件读入内存,进行显示、查找等各项操作。 按照文件的读写要求,先定义一个指向文件的指针,按照r的方式打开已经保存好的文件,输入要打开文件的路径和文件名,fp=open(filename,”r”),同时判断是否正常打开,如果文件打不开,则输出输出信息;否则,利用格式输入函数,先读入记录数,然后利用循环语句,用函数fread(&studi,sizeof(struct student),1,fp);将记录逐条读入,读入的记录保存在结构体数组中。 fp=fopen(“stuAll.dat”,”rb”)为输出打开一个文件 打开是否成功否 是输出提示不能打开文件返回从stuAll.dat文件中读取数据For i=0 to n-1读取数据fwrite(&studi,sizeof(struct student),1,fp)输出学生信息fclose(fp);关闭文件13. ReadStuAllToPao()读取保存的数据,冒泡排序后输出到屏幕并放到stuPao.dat文件先用Read()函数从stuAll.dat文件中读取学生数据到结构体,然后使用冒泡排序法对学生的平均分从大到小排序并输出到屏幕,最后保存到stuPao.dat文件中。 调用Read()读取学生数据For j = 0 to n 1For i = 0 to n 1 j 如果studi.avg studi+1.avg真 假studi.avg 和 studi+1.avg进行交换fwrite(&studi,sizeof(struct student),1,fp)保存数据fclose(fp)关闭文件14. ReadStuAllToSel()读取保存的数据,选择排序后输出到屏幕并放到stuSel.dat文件先用Read()函数从stuAll.dat文件中读取学生数据到结构体,然后使用选择排序法对学生的平均分从大到小排序并输出到屏幕,最后保存到stuSel.dat文件中。 调用Read()读取学生数据For i = 0 to n 1For j = i + 1 to n 1 如果studi.avg studi+1.avg真 假studi.avg 和 studi+1.avg进行交换fwrite(&studi,sizeof(struct student),1,fp)保存数据fclose(fp)关闭文件15ReadPao(),ReadSel(),分别从stuPao.dat和stuSel文件中读取记录函数 ReadPao()和ReadSel()基本相同,不同的只是分别从不同文件中读取学生数据。和Read()函数不同的是它能读取保存的学生平均分和总分。 fp=fopen(“stuPao.dat”,”rb”)为输出打开一个文件 打开是否成功否 是输出提示不能打开文件返回从stuPao.dat文件中读取数据For i=0 to n-1读取数据fwrite(&studi,sizeof(struct student),1,fp)输出学生信息fclose(fp);关闭文件16. Binsrch()二分法查找总分人数 排序是一种较为费时的运算,所以经过了排序,而不加以利用未免可惜,为此设计了一种在排序基础上实现的快速查找算法二分查找法。 二分查找法,首先确定要找的数据是在一个已经从大到小排序好的数组当中,然后检索中间的分数值,如果此分值比要查找的分数值大,就从该数组的后面一半的中间值再开始找,否则则从前面一半开始找,一直到找到该数所在的位置为止。然后从位置向上检索,找出第一个和此数值相等的数的位置,再从该位置向下检索,找到所有总分为该分数的学生人数。从stuPao.dat文件中读入学生的数据While low studmid.sum给出的分值是否大于中间值是 否High = mid 1修改右边界Scorestudmid.sum是 否Low = mid +1修改左边界记录位置人数记录+1While score = studnumber-1.sumNumber - 找到第一个总成绩为此分值的位置While score = studnumber + 1.sumCount+ 人数记录+1Number+ 记录位置关闭文件17StaScore()分析统计函数:除了对学生成绩的总分进行分析外,对各科成绩的分析也是不可或缺的。此函数遍历每个科目的所有成绩,找出其中的最高分,最低分和平均分,并对各科成绩的各个分数段统计出来,算出其合格率。For j = 0 to 2把最高分,最低分,平均分及各分数段的人数都置0For i=0 to n-1 maxScore studi.scorej?是 否把此值赋给minScoreavgScore+=studi.scorej计算平均值用if判断统计各科成绩在各分数段的人数循环输出上述所有数据三、源程序#include#include#include#include #include #define null 0#define LEN sizeof(struct student)struct studentlong num;/记录学号char name10;/记录姓名char grade10;/记录年级char specialty10;/记录专业float score3;/记录三科成绩分数float avg;/记录平均分float sum;/记录总成绩struct student *next;/指向下一结点的指针stud100;int n;/全局变量表示学生人数/*下面是各函数声明*/int Pwd();/密码验证函数int Menu();struct student *creat(void);void print(struct student *head);void DelMain(struct student *head);/继续删除判断函数struct student *del(struct student *head,long num);/删除结点void InputMain(struct student *head);/继续插入判断函数struct student *insert(struct student *head,struct student *stud);/插入结点void Correct(struct student *head);/继续修改判断函数void Save();/把学生数据保存到stuAll.dat文件中void Read();/从stuAll.dat中读取数据void ReadStuAllToPao();/从stuAll.dat中读取数据,冒泡排序后输出到屏幕并放到stuPao.dat文件void ReadStuAllToSel();/从stuAll.dat中读取数据,选择排序后输出到屏幕并放到stuSel.dat文件void ReadPao();/从stuPao.dat中读取数据void ReadSel();/从stuSel.dat中读取数据void printStu(struct student stud100);/输出全部学生结构体void Avg(struct student stud100);/计算平均分void Sum(struct student stud100);/计算总分void Binsrch();/折半查找法void StaScore();/对各科成绩进行统计/主函数void main()int menuNum = 0;/记录选择的菜单功能int contunue;/记录密码是否正确struct student *head;printf(nnnn);printf(ttt*n);printf(ttt* *n);printf(ttt* 学生成绩管理系统 *n);printf(ttt* (口令为000000) *n);printf(ttt*n);contunue = Pwd();/验证密码if(contunue = 1)for(;)switch(Menu() case 0:printf(感谢您的使用,退出程序!n); exit(0); break; case 1:head = creat();/创建列表 print(head); break; case 2:Read();/输出学生的数据 break; case 3:DelMain(head);/删除学生的数据 break; case 4:InputMain(head);/插入学生的数据 break; case 5:Correct(head);/修改学生的数据 break; case 6:ReadStuAllToPao();/用冒泡排序输出到屏幕并放到stuSel.dat文件ReadPao();/输出stuPao.dat文件 break; case 7:ReadStuAllToSel();/用选择排序输出到屏幕并放到stuSel.dat文件ReadSel();/输出stuSel.dat文件 break; case 8: Binsrch();/折半查找法查找总分 break; case 9: StaScore();/对各科成绩进行统计 break;elseprintf(n程序结束);/密码验证函数int Pwd()int i;char pwdPut7 = 0;int pwdNum = 3;for(pwdNum = 3;pwdNum 0;pwdNum-)if(pwdNum = 0)return(0);printf(n请输入口令(你还有%d次机会):,pwdNum);for(i = 0;i 6;i+)pwdPuti=getch();printf(*);getch();if(!strcmp(pwdPut,000000)return(1);return(0);/菜单函数Menu() char s8;int c; printf(n按任意键进入菜单.n);getch();/继续printf(*菜单*nn);printf( 1.输入记录nn);printf( 2.显示记录nn);printf( 3.删除记录nn);printf( 4.插入记录nn);printf( 5.修改记录nn);printf( 6.用冒泡排序nn);printf( 7.用选择排序nn);printf( 8.查询总分为某个值的人数nn);printf( 9.分析统计各科成绩nn);printf( 0.退出nn);printf(*nn);printf(n 输入选项(09):);scanf(%s,s); /输入选项 c=atoi(s); /将输入字符串转化为整型数if(c14)c = 0;/选项不在9时就显为退出return c; /返回选择项,主程序根据该数调用相应的函数/创建链表struct student *creat(void)struct student * head;struct student *p1,*p2;int i;n = 0;p1 = p2 = (struct student*)malloc(LEN);printf(输入学生学号和成绩(要结束学号就输入):n);printf(请输入第%d个学生的数据n,n+1);printf(学号:);scanf(%ld,&p1-num);printf(姓名:);scanf(%s,&p1-name);printf(年级:);scanf(%s,&p1-grade);printf(专业:);scanf(%s,&p1-specialty);for(i = 0;i scorei);head = null;while(p1-num!=0)n = n + 1;if(n = 1)head = p1;else p2-next= p1;p2 = p1;p1 = (struct student*)malloc(LEN);printf(请输入第%d个学生的数据n,n+1);printf(学号:);scanf(%ld,&p1-num);if(p1-num = 0)break;printf(姓名:);scanf(%s,&p1-name);printf(年级:);scanf(%s,&p1-grade);printf(专业:);scanf(%s,&p1-specialty);for(i = 0;i scorei);p2-next = null;return(head);Save();/输出链表void print(struct student *head)int i,j=0;struct student *p;printf(n这%d 个学生的成绩是:n,n);printf(n学号姓名年级专业分数分数分数n);p = head;if(head != null)doprintf(%ldt%st%st%s,p-num,p-name,p-grade,p-specialty);/在输出的同时把值赋给结构体变量stu,以便保存到文件studj.num = p-num;strcpy(,p-name);strcpy(studj.grade,p-grade);strcpy(studj.specialty,p-specialty);for(i = 0;i scorei);studj.scorei = p-scorei;printf(n);p = p-next;j+;while(p!=null);Save();Avg(stud);Sum(stud);/删除结点struct student *del(struct student *head,long num)struct student *p1,*p2;if(head = null)printf(n这是空列表! n);p1 = head;while(num != p1-num & p1-next!=null)p2 = p1;p1=p1-next;if(num = p1-num)if(p1=head)head = p1-next;else p2-next = p1-next;n = n - 1;else printf(没有%ld这个学号n);return(head);/删除判断void DelMain(struct student *head)long del_num;print(head);printf(n请输入你想删除的学号(如果没有就输入):);scanf(%ld,&del_num);while(del_num != 0)head = del(head,del_num);print(head);printf(n请输入你想删除的学号(如果没有就输入):);scanf(%ld,&del_num);print(head);/插入结点struct student *insert(struct student *head,struct student *stud)struct student *p0,*p1,*p2;p1 = head;p0 = stud;if(head = null)head = p1;p0-next=null;elsewhile(p0-num p1-num)&(p1-next!=null)p2=p1;p1=p1-next;if(p0-numnum)if(head = p1)head = p0;else p2-next = p0;p0-next = p1;elsep1-next = p0;p0-next = null;n = n+1;return(head);/插入判断void InputMain(struct student *head)struct student *stu;int i;printf(输入你想插入的数据(如果没有就输入):n);stu = (struct student *)malloc(LEN);printf(学号:);scanf(%ld,&stu-num);printf(姓名:);scanf(%s,&stu-name);printf(年级:);scanf(%s,&stu-grade);printf(专业:);scanf(%s,&stu-specialty);for(i = 0;i scorei);while(stu-num !=0)head = insert(head,stu);print(head);printf(输入你想插入的数据:n);stu = (struct student *)malloc(LEN);printf(学号:);scanf(%ld,&stu-num);if(stu-num = 0)break;printf(姓名:);scanf(%s,&stu-name);printf(年级:);scanf(%s,&stu-grade);printf(专业:);scanf(%s,&stu-specialt

温馨提示

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

评论

0/150

提交评论