版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、目录1.概述.31.1项目背景.31.1功能需求分析.3 1.2编写目的.3 1.3开发环境.32.需求分析.42.1功能需求分析.42.2环境需求分析.42.3方法需求分析.43.概要设计.43.1系统功能模块图.43.2设计思想.54.主要代码描述54.1显示主菜单.64.2显示排序方式.64.3输入学生信息.74.4删除学生信息.84.5详细代码叙述.95.调试过程296.结束语31参考文献.32摘要随着计算机技术的发展,可视编程技术占有了越来越重要的作用。visual c+6.0 是一种功能强大行之有效的可视化编程工具。因此此软件是在visual c+6.0环境下编写的。对于我们,随着
2、学习的深入,已经大体掌握了visual c+6.0环境下的程序开发。为了将我们的编程能力提升到一个更高的水平,深化面向对象的编程思维和解决问题的能力,值此课程设计周期间,进行基于visual c+6.0环境的软件开发,先以字符统计软件作为开始,对visual c+6.0环境和面向对象程序设计进行回忆和熟悉,使得在此基础上的下一个员工培训系统软件的开发进行的更加顺利。本文档从概要设计,详细设计,参考源程序代码以及显示程序运行的截屏等方面详尽的介绍了软件开发过程。学生成绩管理系统能方便用户迅速、准确处理学生的成绩,得到想要的数据并能将学生的信息以文档保存。本文介绍了简易学生成绩管理系统在micro
3、soft visual c+ 6.0环境下的实现过程:系统的分析,功能模块的设计,系统的调试和测试。此系统的主要管理的信息有:学生的班级,学号,姓名和三(可以更改)门课的成绩。本系统的主要功能有学生成绩的添加、删除、插入、显示,能对学生成绩按分数或学号进行排序,可以根据用户的要求按班级,姓名,学号查询学生的成绩信息,计算每位学生的总分和均分,计算所有同学的总分和平均分,分类汇总统计每门课的的总分均分能保存信息到文件以及从文件中读取信息等功能。关键词:项目;学生成绩管理系统;功能模块(函数).abstract:with the development of computer technology
4、, visual programming technology occupy a more and more important role. visual c + + 6.0 is a powerful effective visual programming tools. therefore this software is in visual c + + 6.0 environment benefit. for us, with learning deeply, has generally grasped visual c + + 6.0 environment program devel
5、opment. to make our programming ability elevated to a higher level, deepening of object-oriented programming thinking and problem-solving ability, in the curriculum design of weeks, based on visual c + + 6.0 environment of software development, first in character statistical software for visual c +
6、+, as a start 6.0 environment and object-oriented progam design, makingmemories and familiar with on the basis of the next employee training software development of more smoothly. this document from the outline design, detailed design, reference source code and display the program runs the screensho
7、ts aspects detailed introduces the software development process. students performance management system can convenient user fast, accurate processing students scores, the desired data and students information according to the document preservation. this paper introduces the simple student performanc
8、e management system in microsoft visual c + + 6.0 environment of realization process: system analysis, function module design, system commissioning and testing. the systems main management information are: student class, student id, name and three (can change) course grades. the systems main functio
9、n of the students grade add, delete, insert, display, can according to the grades of student achievement or student id sorting, can according to the users requirements according to class, name, student id inquires the student performance information, calculate each students overall score and partiti
10、oning, computing all classmate of total score peace, collect classified statistical divide each course total score alike can store information from the document to the file and read information, and other functions.keywords: projects;students performance management system;function modle function.1概述
11、本系统是基于vc平台开发的,用c来完成此课题。深入了解数据的组织,存储,处理逻辑及数据的显示。在用c完成课题的过程中去体会数据是如何组织和存储的,数据是如何显示的,数据的处理逻辑是什么。该系统的功能是以菜单方式工作,用户通过选择数字来选择学生信息录入功能-输入学生基本信息,学生信息浏览功能-输出学生的基本信息,查询、排序功能-算法,按学号查询,按姓名查询。学生信息的删除与修改(可选项)的等基本的功能,从而实现用户的想法。在各项基本功能之下我们可以看到各种小的模块来满足用户的各种需求,达到快速方便的效果。1.1 项目背景随着现代科技的发展,互联网时代的到来,电脑给人们带来了很大的便利。学生信息管
12、理系统可以为学校师生提供查询、修改、统计等服务,为学校管理提供了极大的方便。1.2 编写目的通过对学生信息管理系统的编写,实现对学生信息的快速查找,添加,删除统计等功能,同时通过此次课程设计进一步加深对数据处理的各方面理解。1.3 开发环境采用visual c+6.02.需求分析2.1功能需求分析学生信息包括:姓名,班级,学号,性别,出生年月(其它信息可酌情增加)需要完成的各项功能:(1)添加学生信息:输入并保存学生信息 (2)显示学生信息:出现“显示学生信息子菜单”,供操作者选择 (3)删除学生信息:显示现有的学生信息,让操作者输入要删除学生的学号,将其删除后再次显示其余的学生信息 (4)查
13、询学生信息:出现“查询学生信息子菜单”,供操作者选择 (5)修改学生信息:出现“修改学生信息子菜单”,供操作者选择(6)统计学生信息:统计并显示优、良、中、及格、不及格的人数与比例,以及总人数、及格率、最高分、最低分、平均分(包括一个学生多门课的学生成绩,和某一门课的学生平均成绩)。2.2 环境需求分析:操作系统: windows 7开发软件: visual c+ 6.02.3 方法需求分析由于数组存放数据的时候要先确定数组的规模,不能动态的分配内存空间,而单链表是非连续存放的,可以对内存空间进行动态分配,此系统是用单链表完成的。然后定义链表的结点类型为结构就可以实现对学生学号、姓名、成绩、班
14、级等学生信息保存。每次只要返回头指针,就可以对整个链表进行操作,因此选链表来存放学生信息。3概要设计3.1 系统功能模块图系统功能单元: 学生成绩管理系统添加学生信息显示学生信息删除学生信息查询学生信息修改学生信息统计学生信息1.按名字2.按学号3.按英语成绩4.按平均成绩1.按名字2.按学号3.模糊查找1.英语成绩2.java成绩3.数学成绩4.语文成绩5.c成绩5学生成绩统计各个功能单元完成情况良好,均能准确并且快速的实现课题所需功能。3.2 设计思想:(1)学生信息管理系统的功能为显示主要操作页面。学生信息处理功能包括输入学生信息,显示学生的个人信息,学生信息条件查询(分为:按学生姓名进
15、行查询,按学生学号进行查询),更新学生个人信息。(2)学生信息管理系统的功能模块有:系统登陆界面,美观大方,按enter键进入主菜单选择框架界面,方便用户对程序个功能进行选择,选择要实现的功能按enter键进入该功能。1. 添加学生信息。2. 显示学生信息3. 删除学生4. 查询学生信息。5. 修改学生信息6. 统计学生信息0. 退出程序分为多个小模块,通过调用实现各种功能,增强了程序的可建设性。学生信息管理系统是用面向对象的方法设计,由于数组的存放是连续的,而单链表是非连续存放的,是动态分配内存空间,因此此系统采用单链表来完成。各个功能模块的实现主要转变到对单链表的遍历,添加和删除结点。4主
16、要代码描述 4.1显示主菜单void displaymainmenu()/作者:闾泽民printf(系统的主菜单:n);printf(n欢迎来到学生成绩管理系统!在该系统你可以。n);printf(nt1:添加学生信息n);printf(nt2:显示学生信息n);printf(nt3:删除学生信息n);printf(nt4:查询学生信息n);printf(nt5:修改学生信息n);printf(nt6:统计学生信息n);printf(nt0:退出系统n);printf(nt请选择:);4.2显示排序方式void name(student stu,int max)/按名字排序/作者:不详int
17、i,j;student p;for(i=0;imax;i+)for(j=0;j0)p=stuj;stuj=stuj+1;stuj+1=p;display(stu,max);void sort(student stu,int max)/按学号排序/作者:不详int i,j;student p;for(i=0;i max;i+)for(j=0;j stuj+1.num)p=stuj;stuj=stuj+1;stuj+1=p;display(stu,max);4.3输入学生信息 int inforinput(student stu,int id)/学生信息输入/作者:不详 int number,i,
18、m;printf(nt请输入本次录入的学生人数:);scanf(%d,&number);m=number+id;if(numbermaxnum)printf(输入人数太多,请重新输入!n);return (0);for(i=id;inumber+id;i+)printf(nt请输入第%d个学生人数的学号:,i+1);scanf(%d,&stui.num);printf(nt姓名:);scanf(%s,); printf(nt班级:);scanf(%d,&stui.classes);printf(nt性别: ); scanf(%s,stui.sex);printf(nt请依次输
19、入英语,java,语文,c,数学的成绩:);scanf(%f%f%f%f%f,&stui.mark.english,&stui.mark.java,&stui.mark.chinese,&stui.mark.c,&stui.mark.math);printf(nt你输入的信息是:n);savestu(stu,i);for(i=id;inumber+id;i+)printf(nt姓名:%st班级:%dt学号:%dt性别:%sn,,stui.classes,stui.num,stui.sex);printf(nt学生成绩信息:n);printf(ntenglish:%.2ftja
20、va:%.2ftchinese:%.2ftc:%.2ftmath:%.2fn,stui.mark.english,stui.mark.java,stui.mark.chinese,stui.mark.c,stui.mark.math); return (i); 4.4 删除学生信息int delete(student stu,int max)/作者:不详int j,i;int findnum;printf(nt请输入要删除的学号:);scanf(%d,&findnum);while(findnum!=0)if(i=findstunum(stu,findnum,max)!=-1)for(j=i;
21、jmax-1;j+)stuj.num=stuj+1.num;strcpy(,stuj+1.name);stuj.classes=stuj+1.classes;strcpy(stuj.sex,stuj+1.sex);stuj.mark.english=stuj+1.mark.english;stuj.mark.java=stuj+1.mark.java;stuj.mark.chinese=stuj+1.mark.chinese;stuj.mark.c=stuj+1.mark.c;stuj.mark.math=stuj+1.mark.math;max=max-1;savestu(
22、stu,max);printf(nt删除完毕!n);elseprintf(nt没有你输入的学号!n);printf(nt请输入要删除的学号,退出请按0:);scanf(%d,&findnum);display(stu,max);return (max);4.5详细代码描述#include#include#include#include#include#define maxnum 2000#define filename student.txt/定义结构体struct score float english;float java;float chinese;float c;float math;
23、typedef struct studentint num;char name10;int classes;char sex10;struct score mark;student;/函数void savestu(student stu,int max);void displaystuinf(student stu,int max);void displaymainmenu();int delete(student stu,int max);int inforinput(student stu,int id);int read(student stu);void sort(student st
24、u,int max);int findstunum(student stu,int findunm,int max);int findstuname(student stu,char findname,int max);void queryinformation(student stu,int max);/查询学生信息void edit(student stu,int max);void name(student stu,int max);void englishcore(student stu,int max);void averagecore(student stu,int max);vo
25、id display(student stu,int max);void count(student stu,int max);void english(student stu,int max);void java(student stu,int max);void chinese(student stu,int max);void c(student stu,int max);void math(student stu,int max);void stucore(student stu,int max);void count(student stu,int max)int select;pr
26、intf(nt1.英语成绩统计nnt2.java成绩统计nnt3.语文成绩统计nnt4.c成绩统计nnt5.数学成绩统计nnt6.学生成绩统计nnt0.退出nt);printf(nt请选择:);scanf(%d,&select);while(select!=0)switch(select)case 1:english(stu,max);break;case 2:java(stu,max);break;case 3:chinese(stu,max);break;case 4:c(stu,max);break;case 5:math(stu,max);break;case 6:stucore(st
27、u,max);break;default:printf(nt输入错误!请重新输入!n);printf(nt);scanf(%d,&select);void english(student stu,int max)int i,you,liang,zhong,jige,buji;float high,low,sum,n,av;sum=0;you=0;liang=0;zhong=0;jige=0;buji=0;low=stu0.mark.english;high=stu0.mark.english;printf(nt英语成绩统计:n);printf(nt优t良t中t及格t不及格t最高分t最低分t平均
28、分t及格率n);for(i=0;ihigh)high=stui.mark.english;if(stui.mark.english=90)you+;else if(stui.mark.english=80)liang+;else if(stui.mark.english=70)zhong+;else if(stui.mark.english=60)jige+;elsebuji+;n=100*(max-buji)/(float)max;av=sum/max;printf(nt%dt%dt%dt%dt%dt%.2f t%.2f t%.2ft %.1f%n,you,liang,zhong,jige,
29、buji,high,low,av,n);void java(student stu,int max)int i,you,liang,zhong,jige,buji;float high,low,sum,n,av;sum=0;you=0;liang=0;zhong=0;jige=0;buji=0;low=stu0.mark.java;high=stu0.mark.java;printf(ntjava成绩统计:n);printf(nt优t良t中t及格t不及格t最高分t最低分t平均分t及格率n);for(i=0;ihigh)high=stui.mark.java;if(stui.mark.java=
30、90)you+;else if(stui.mark.java=80)liang+;else if(stui.mark.java=70)zhong+;else if(stui.mark.java=60)jige+;elsebuji+;n=100*(max-buji)/(float)max;av=sum/max;printf(t%dt%dt%dt%dt%dt%.2ft%.2ft%.2ft%.1f%n,you,liang,zhong,jige,buji,high,low,av,n);void chinese(student stu,int max)int i,you,liang,zhong,jige
31、,buji;float high,low,sum,n,av;sum=0;you=0;liang=0;zhong=0;jige=0;buji=0;low=stu0.mark.chinese;high=stu0.mark.chinese;printf(nt语文成绩统计:n);printf(nt优t良t中t及格t不及格t最高分t最低分t平均分t及格率n);for(i=0;ihigh)high=stui.mark.chinese;if(stui.mark.chinese=90)you+;else if(stui.mark.chinese=80)liang+;else if(stui.mark.chin
32、ese=70)zhong+;else if(stui.mark.chinese=60)jige+;elsebuji+;n=100*(max-buji)/(float)max;av=sum/max;printf(nt%dt%dt%dt%dt%dt%.2ft%.2ft%.2ft%.1f%n,you,liang,zhong,jige,buji,high,low,av,n);void c(student stu,int max)int i,you,liang,zhong,jige,buji;float high,low,sum,n,av;sum=0;you=0;liang=0;zhong=0;jige
33、=0;buji=0;low=stu0.mark.c;high=stu0.mark.c;printf(ntc成绩统计:n);printf(nt优t良t中t及格t不及格t最高分t最低分t平均分t及格率n);for(i=0;ihigh)high=stui.mark.c;if(stui.mark.english=90)you+;else if(stui.mark.c=80)liang+;else if(stui.mark.c=70)zhong+;else if(stui.mark.c=60)jige+;elsebuji+;n=100*(max-buji)/(float)max;av=sum/max;p
34、rintf(nt%dt%dt%dt%dt%dt%.2ft%.2ft%.2ft%.1f%n,you,liang,zhong,jige,buji,high,low,av,n);void math(student stu,int max)int i,you,liang,zhong,jige,buji;float high,low,sum,n,av;sum=0;you=0;liang=0;zhong=0;jige=0;buji=0;low=stu0.mark.math;high=stu0.mark.math;printf(nt数学成绩统计:n);printf(nt优t良t中t及格t不及格t最高分t最低
35、分t平均分t及格率n);for(i=0;ihigh)high=stui.mark.math;if(stui.mark.math=90)you+;else if(stui.mark.math=80)liang+;else if(stui.mark.math=70)zhong+;else if(stui.mark.math=60)jige+;elsebuji+;n=100*(max-buji)/(float)max;av=sum/max;printf(nt%dt%dt%dt%dt%dt%.2ft%.2ft%.2ft%.1f%n,you,liang,zhong,jige,buji,high,low,
36、av,n);void stucore(student stu,int max)int i,j;float sum=0;student p;float av;printf(nt学生成绩统计:n);for(i=0;imax;+i)for(j=0;jstuj+1.mark.english+stuj+1.mark.chinese+stuj+1.mark.math+stuj+1.mark.c+stuj+1.mark.java)p=stuj;stuj=stuj+1;stuj+1=p;for(i=0;imax;i+)av=(stui.mark.english+stui.mark.chinese+stui.m
37、ark.math+stui.mark.c+stui.mark.java)/5;printf(nt名字t学号t英语t语文t数学tctjavat平均分n);printf(nt%st%dt%.2ft%.2ft%.2ft%.2ft%.2ft%.2fn,,stui.num,stui.mark.english,stui.mark.chinese,stui.mark.math,stui.mark.c,stui.mark.java,av);/显示主菜单void displaymainmenu()printf(系统的主菜单:n);printf(n欢迎来到学生成绩管理系统!在该系统你可以。n);
38、printf(nt1:添加学生信息n);printf(nt2:显示学生信息n);printf(nt3:删除学生信息n);printf(nt4:查询学生信息n);printf(nt5:修改学生信息n);printf(nt6:统计学生信息n);printf(nt0:退出系统n);printf(nt请选择:);void display(student stu,int max)int i;for(i=0;imax;i+)printf(nt姓名:%s t班级:%d t学号:%d t性别:%sn,,stui.classes,stui.num,stui.sex);printf(nt学生成绩
39、信息:n);printf(t英语:%.2f tjava:%.2f t语文:%.2ftc:%.2f t数学:%.2fn,stui.mark.english,stui.mark.java,stui.mark.chinese,stui.mark.c,stui.mark.math);void displaystuinf(student stu,int max)int select;printf(nt1.按名字顺序显示n);printf(nt2.按学号顺序显示n);printf(nt3.按英语成绩顺序显示n);printf(nt4.按所有课程平均成绩显示n);printf(nt0.退出n);printf
40、(nt请选择:);scanf(%d,&select);while(select!=0)switch(select)case 1:printf(nt1.按名字顺序显示n);name(stu,max);break;case 2:printf(nt2.按学号顺序显示n);sort(stu,max);break;case 3:printf(nt3.按英语成绩顺序显示n);englishcore(stu,max);break;case 4:printf(nt4.按所有课程平均成绩显示n);averagecore(stu,max);break;case 0:displaymainmenu();break;
41、default:printf(nt输入错误!请重新输入!n);printf(nt);scanf(%d,&select);void name(student stu,int max)/按名字排序int i,j;student p;for(i=0;imax;i+)for(j=0;j0)p=stuj;stuj=stuj+1;stuj+1=p;display(stu,max);void sort(student stu,int max)/按学号排序int i,j;student p;for(i=0;i max;i+)for(j=0;j stuj+1.num)p=stuj;stuj=stuj+1;stu
42、j+1=p;display(stu,max);void englishcore(student stu,int max)int i,j;student p;for(i=0;imax;+i)for(j=0;jstuj+1.mark.english)p=stuj;stuj=stuj+1;stuj+1=p;display(stu,max);void averagecore(student stu,int max)int i,j;student p;for(i=0;i max;+i)for(j=0;j stuj+1.mark.english+stuj+1.mark.java+stuj+1.mark.c
43、hinese+stuj+1.mark.c+stuj+1.mark.math)p=stuj;stuj=stuj+1;stuj+1=p;display(stu,max);int inforinput(student stu,int id)/学生信息输入int number,i,m;printf(nt请输入本次录入的学生人数:);scanf(%d,&number);m=number+id;if(numbermaxnum)printf(输入人数太多,请重新输入!n);return (0);for(i=id;inumber+id;i+)printf(nt请输入第%d个学生人数的学号:,i+1);scanf(%d,&stui.num);printf(nt姓名:);scanf(%s,); printf(nt班级:);scanf(%d,&stui.classes);printf(nt性别: ); scanf(%s,stui.sex);printf(nt请依次输入英语,java,语文,c,数学的成绩:);scanf(%f%f%f%f%f,&s
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年度新型电动出租车购置合同范本4篇
- 2025年度协议离婚房产分割合同范本3篇
- 2024起重机研发、制造与销售合作框架合同3篇
- 2024版建筑脚手架施工安全合作合同书版B版
- 2024药品研发生产项目廉洁合作合同范本3篇
- 2024智能化仓储管理系统采购与升级合同2篇
- 2025年度知识产权出借与咨询服务合同4篇
- 2025年度知识产权评估居间合同上诉状4篇
- 2024离婚双方关于调解程序的协议
- 2024版毛竹购销合同模板
- 春节行车安全常识普及
- 电机维护保养专题培训课件
- 汽车租赁行业利润分析
- 春节拜年的由来习俗来历故事
- 2021火灾高危单位消防安全评估导则
- 佛山市服务业发展五年规划(2021-2025年)
- 房屋拆除工程监理规划
- 医院保安服务方案(技术方案)
- 高效能人士的七个习惯:实践应用课程:高级版
- 小数加减法计算题100道
- 通信电子线路(哈尔滨工程大学)智慧树知到课后章节答案2023年下哈尔滨工程大学
评论
0/150
提交评论