学生成绩管理系统 综合程序设计.docx
- 文档编号:7442150
- 上传时间:2023-01-24
- 格式:DOCX
- 页数:13
- 大小:25.26KB
学生成绩管理系统 综合程序设计.docx
《学生成绩管理系统 综合程序设计.docx》由会员分享,可在线阅读,更多相关《学生成绩管理系统 综合程序设计.docx(13页珍藏版)》请在冰豆网上搜索。
学生成绩管理系统综合程序设计
实验16综合程序设计
1.实验学时
2学时
2.实验目的
(1)熟练掌握函数的定义和使用;
(2)熟练掌握结构体类型数据的概念和使用;
(3)熟练掌握文件的操作方式以及常用函数;
(4)掌握用模块化分析与设计方法解决实际问题。
3.实验设备
PC计算机,配置Win7操作系统,Word2010,Eclipse+minGW
4.实验内容及步骤
设计一个学生成绩管理系统,实现添加记录、显示记录、修改记录、删除记录、查找记录、排序记录及退出系统等功能。
图16-1
4.1需求分析
根据题目要求,学生管理系统需要实现添加记录、显示记录、修改记录、删除记录、查找记录、排序记录及退出系统等7项功能。
图16-1显示学生成绩管理系统的所有需实现的功能模块及彼此之间的关联关系,该图的每一个功能都会对应一个界面。
该系统首先会向用户展现一个菜单选择界面,用户可以根据菜单界面的提示,选择不同功能进入子界面。
4.1.1添加记录
本功能用于添加学生的信息,当用户在功能菜单中选择数字1时,会进入添加记录模块,提示用户输入学生的学号、姓名、数学成绩、语文成绩。
当用户输入完毕后,会提示用户是否继续添加,Y表示继续,N表示返回。
需要注意:
在添加学号时不能重复,如果输入重复的学号就会提示此学号存在。
4.1.2显示记录
本功能用于显示已存入的学生信息,当用户在功能菜单中选择数字2时,会进入显示记录模块,并向控制台输出录入的所有学生的学号、姓名、数学成绩、语文成绩和成绩总和。
4.1.3修改记录
本功能用于修改学生信息,当用户在功能菜单中选择数字3时,会进入修改记录模块。
输入要修改的学生姓名,当用户输入了已录入的学生姓名后,如果学生信息存在即可修改除学号以外的其他信息,否则输出该学生不存在。
4.1.4删除记录
本功能用于删除已录入的学生信息,当用户在功能菜单中选择数字4时,会进入删除记录模块。
对学生学号进行判断,如果学号存在即可删除该生的所有信息,否则输出没有找到该生的记录。
4.1.5查找记录
本功能用于查找某个学生信息,当用户在功能菜单中选择数字5时,会进入查找记录模块。
在该模块中输入查找的学生姓名,如果该学生存在则输出该生的全部信息,否则输出没找到该生的记录。
4.1.6排序记录
本功能用于对总成绩进行排序,当用户在功能菜单中选择数字6时,会进入排序记录模块。
该模块会输出所有学生的信息,并按总成绩由高到低进行排序。
4.1.7退出系统
本功能用于退出系统,当用户在功能菜单中选择数字0时,即可退出系统。
4.2数据设计
根据系统分析,需要确定项目中的数据。
由于学生成绩管理系统中多次涉及学生信息及其成绩信息的操作,因此根据学生成绩管理系统的需求,设计学生的数据如表16-1所示
表16-1学生数据
变量声明
功能描述
intid
存储学生学号
charname[8]
学生姓名
intchinese
语文成绩
intmath
数学成绩
intsum
总成绩
由于学生的数据各不相同,为便于统一管理,可以使用结构体类型来声明。
在项目开发时,除根据需求对项目中的数据进行设计外,还需要规划项目中需要定义的函数。
表16-2描述了本项目所需的函数及其功能描述
表16-2功能函数
函数声明
功能描述
voidmenu()
显示功能菜单
voidadd(structstudentstu[])
添加学生信息
voidshow(structstudentstu[],inti)
显示某个学生信息
voidshowAll(structstudentstu[])
显示所有学生信息
voidmodify(structstudentstu[])
修改某个学生信息
voiddel(structstudentstu[])
删除某个学生信息
voidsearch(structstudentstu[])
查询某个学生信息
voidsort(structstudentstu[])
对学生成绩进行排序
至此,项目的分析与初步设计已完成,后面就是需要对每一部分用程序进行实现,请同学们完成。
实验源程序如下:
-_-
综合程序设计:
/*
*student.c
*
*Createdon:
2015年12月29日
*Author:
PC
*/
#include"student.h"
voidmenu()
{
system("cls");
printf("\n");
setvbuf(stdout,NULL,_IONBF,0);
printf("\t\t--------------学生成绩管理系统--------------\n");
printf("\t\t|\t\t1添加记录|\n");
printf("\t\t|\t\t2显示记录|\n");
printf("\t\t|\t\t3修改记录|\n");
printf("\t\t|\t\t4删除记录|\n");
printf("\t\t|\t\t5查找记录|\n");
printf("\t\t|\t\t6排序记录|\n");
printf("\t\t|\t\t0退出系统|\n");
printf("--------------------------------------------\n");
printf("\t\t请选择(0-6):
");
}
voidadd(structstudentstu[])
{
inti,id=0;
charquit;
do
{
printf("学号:
");
scanf("%d",&id);
for(i=0;i { if(id==stu[i].id) { printf("此学号已存在! \n"); return; } } stu[i].id=id; printf("请输入姓名: "); scanf("%s",stu[i].name); printf("请输入语文成绩: "); scanf("%d",&stu[i].chinese); printf("请输入数学成绩: "); scanf("%d",&stu[i].math); stu[i].sum=stu[i].chinese+stu[i].math; n++; printf("是否继续添加? (Y/N)? "); scanf("\t%c",&quit); }while(quit! ='n'&&quit! ='N'); } voidshow(structstudentstu[],inti) { printf("%-10d",stu[i].id); printf("%-10s",stu[i].name); printf("%-10d",stu[i].chinese); printf("%-10d",stu[i].math); printf("%-10d",stu[i].sum); } voidshowall(structstudentstu[]) { inti; HH; for(i=0;i { show(stu,i); printf("\n"); } } voidmodify(structstudentstu[]) { charname[8],ch; inti; printf("修改学生记录\n"); printf("请输入学生的姓名: "); scanf("%s",name); for(i=1;i { if(strcmp(stu[i].name,name)==0) { getchar(); printf("找到学生的记录,如下所示: "); HH; show(stu,i); printf("是否修改? (Y/N)? "); scanf("%c",&ch); if(ch=='y'||ch=='Y') { getchar(); printf("请输入姓名: "); scanf("%s",stu[i].name); printf("请输入语文成绩: "); scanf("%d",&stu[i].chinese); printf("请输入数学成绩: "); scanf("%d",&stu[i].math); stu[i].sum=stu[i].chinese+stu[i].math; printf("修改完毕\n"); } return; } } printf("没找到该学生的记录\n"); } voiddel(structstudentstu[]) { intid,i; charch; printf("删除学生的记录\n"); printf("请输入学号: "); scanf("%d",&id); for(i=0;i { if(id==stu[i].id) { getchar(); printf("找到学生的记录,如下所示: \n"); HH; show(stu,i); printf("是否删除? (Y/N)? \n"); scanf("%c",&ch); if(ch=='y'||ch=='Y') { for(;i { stu[i]=stu[i+1]; } n--; printf("删除成功"); } } return; } } voidsearch(structstudentstu[]) { charname[8]; inti; printf("查找学生的记录\n"); printf("请输入学生的姓名: "); scanf("%s",name); for(i=0;i { if(strcmp(name,stu[i].name)==0) { printf("找到学生的记录,如下所示: "); HH; show(stu,i); return; } } } voidsort(structstudentstu[]) { inti,j; structstudentt; printf("按学生成绩进行排序\n"); for(i=0;i { for(j=i+1;j { if(stu[i].sum { t=stu[i]; stu[i]=stu[j]; stu[j]=t; } } } printf("排序的结果如下: \n"); showall(stu); } /* *stumanagement.c * *Createdon: 2015年12月29日 *Author: PC */ #include #include"student.h" intmain() { structstudentstu[50]; intselect,quit=0; while (1) { menu(); scanf("%d",&select); switch(select) { case1: add(stu); break; case2: showall(stu); break; case3: modify(stu); break; case4: del(stu); break; case5: search(stu); break; case6: sort(stu); break; case0: quit=1; break; default: printf("请输入0-6之间的数字"); break; } if(quit==1) break; printf("按任意键返回主菜单! \n"); getchar(); getchar(); } printf("程序结束! \n"); return0; } /* *student.h * *Createdon: 2015年12月29日 *Author: PC */ #ifndefSTUDENT_H_ #defineSTUDENT_H_ #include #include #include #defineHHprintf("%-10s%-10s%-10s%-10s%-10s\n","学号","姓名","语文","数学","总分"); structstudent{ intid; charname[8]; intchinese; intmath; intsum; }; staticintn; voidmenu(); voidadd(structstudentstu[]); voidshow(structstudentstu[],inti); voidshowall(structstudentstu[]); voidmodify(structstudentstu[]); voiddel(structstudentstu[]); voidsearch(structstudentstu[]); voidsort(structstudentstu[]); #endif/*STUDENT_H_*/ 欢迎您的下载, 资料仅供参考! 致力为企业和个人提供合同协议,策划案计划书,学习资料等等 打造全网一站式需求
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 学生成绩管理系统 综合程序设计 学生 成绩管理系统 综合 程序设计