C语言程序设计学生成绩管理系统设计范本模板Word文件下载.docx
- 文档编号:22008059
- 上传时间:2023-02-02
- 格式:DOCX
- 页数:28
- 大小:157.05KB
C语言程序设计学生成绩管理系统设计范本模板Word文件下载.docx
《C语言程序设计学生成绩管理系统设计范本模板Word文件下载.docx》由会员分享,可在线阅读,更多相关《C语言程序设计学生成绩管理系统设计范本模板Word文件下载.docx(28页珍藏版)》请在冰豆网上搜索。
相关函数:
结构体函数、main(主函数)、Input(输入函数)、Output(输出函数)、Findname(按姓名查询函数)、Findno(按学号查询函数)、Delete(删除函数)、Insert(插入函数)、Rank(排序函数)、exit(退出函数)
4.1输入学生信息
输入学生信息就是对定义的结构体中的成员进行赋值。
其中,用户需要输入的是学号、姓名、班级、数学成绩、英语成绩、计算机成绩,以及是否继续的指令,总成绩由求和函数实现。
代码如下:
voidInput()//用户自定义Input函数,实现数据的输入功能.
{
chark,x[20];
while(k!
='
n’&&
k!
=’N'
)//当输入的不是N或者n时,执行该循环。
{
printf(”输入学生学号:
"
);
scanf(”%s”,stu[n].no);
printf(”输入学生姓名:
);
scanf(”%s”,stu[n].name);
printf(”输入学生班级:
scanf(”%s"
,stu[n].Class);
printf(”输入学生的数学成绩:
scanf("
%d"
,&stu[n]。
math);
printf(”输入学生的英语成绩:
%d"
,&stu[n].english);
printf(”输入学生的计算机成绩:
scanf(”%d"
&stu[n].computer);
stu[n].all=stu[n]。
math+stu[n].english+stu[n].computer;
//输入学生的各项信息,并赋值到结构体中。
gets(x);
//清除多余的输入内容。
printf(”输入下一个?
(Y/N)\n"
scanf(”%c”,&k);
n++;
//执行完一次循环后,将全局变量n(成员数)自增1。
}
}
4.2输出学生信息
输出学生信息就是将结构体中所有成员的各个元素的值显示在屏幕上,使用%—10d或者%-10s格式(左对齐,每个数据占10列)可将数据用表列形式输出,使用循环语句将i个成员信息全部输出。
voidOutput()//用户自定义Output函数,实现数据的输出功能。
inti;
printf("
——-———------——-—---——---————-—--——-——-----—-———-—--——-———-—-—-————-\n”);
printf(”学号姓名班级数学英语计算机总成绩\n”);
printf(”-—-——-—-—-—-————-----———--—-—---——--——-—-———-——--——----——-----—-—-—\n"
for(i=0;
i<
n;
i++)
{
printf(”%-10s%—10s%-10s%—10d%—10d%-10d%—10d\n"
stu[i]。
no,stu[i]。
name,stu[i].Class,stu[i]。
math,stu[i]。
english,stu[i].computer,stu[i].all);
—-—-——---—---—---—-—————-—---—-————-———----———-—-———--—-———--------\n”);
}//使用for循环语句,输出结构体中所有成员信息.
}
4.3删除学生信息
删除学生信息就是将第i+1个成员的每个元素赋值到要删除的第i个成员的相应元素的位置上,再输出结构体中的前i个成员信息,使用循环结构依次执行到第n个成员,实现对第i个成员的删除。
voidDelete()//用户自定义Output函数,实现数据的输入功能.
charx[20];
//输入要删除的学生姓名,char型数据占20列。
intj,i=0;
输入要删除的学生姓名:
”);
scanf(”%s”,x);
while(strcmp(stu[i].name,x)!
=0&&i<
n)
i++;
//比较输入的x数据与结构体中name元素,若不相同,i自增1。
if(i==n)
printf("
未找到相关学生信息!
\n”);
}//若i与n值相同,说明无此数据,输出“未找到学生信息!
”。
for(j=i;
j〈n-1;
j++)
strcpy(stu[j]。
no,stu[j+1].no);
strcpy(stu[j]。
name,stu[j+1].name);
strcpy(stu[j]。
Class,stu[j+1].Class);
//将stu[j+1]中的内容复制到stu[j]中。
stu[j]。
math=stu[j+1].math;
stu[j].english=stu[j+1]。
english;
stu[j].computer=stu[j+1]。
computer;
stu[j].all=stu[j+1]。
all;
}//将结构体中的元素赋值给前一元素.
n--;
//数据删除后,全局变量n值(成员数)自减1.
printf(”该学生信息已删除!
\n"
4。
4查询学生信息
1根据姓名查询
按照学生姓名查找学生信息,要求用户输入学生的姓名,再与结构体中的数据进行一一比对,输出结构体中与该数据相同的成员的所有信息,从而实现查找功能。
voidFindname()//用户自定义函数,实现对指定数据的查找功能.
chars[20];
//定义用户输入的学生姓名数据为char型,占20列。
inti=0;
请输入要查询的学生姓名:
scanf("
%s”,s);
while(strcmp(stu[i].name,s)!
=0&
&
i〈n)
//当输入的姓名与当前姓名不相同时,i自增1,比较下一个成员。
printf(”未找到相关学生信息!
}
printf(”-—--—---—--————--—---——————-——---—--—----—-———————--——-—--——-——-—-—\n”);
printf(”学号姓名班级数学英语计算机总成绩\n”);
printf(”-—-—-——————-—---——--—-----———----—-—----————---——--——-—---—---—--——\n”);
printf(”%-10s%—10s%-10s%-10d%—10d%—10d%-10d\n”,stu[i]。
no,stu[i]。
name,stu[i]。
Class,stu[i]。
math,stu[i]。
english,stu[i].computer,stu[i].all);
-----—-———-—---—----—-———-—-——-—-—-—-———-——-—---——--———-—----—----—\n”);
}//以表列的形式输出查找到的成员的相关信息。
2根据学号查询
按照学生学号查找学生信息,要求用户输入学生的学号,再与结构体中的数据进行一一比对,输出结构体中与该数据相同的成员的所有信息,从而实现查找功能。
voidFindno()//用户自定义函数,实现对指定数据的查找功能。
chars[20];
//定义用户输入的学生学号数据为char型,占20列.
printf(”请输入要查询的学生学号:
%s"
s);
while(strcmp(stu[i].no,s)!
=0&&i〈n)
//当输入的学号与当前学号不相同时,i自增1,比较下一个成员。
if(i==n)
}
printf(”———-——--—-—---—-------————----——--—---——————--———-—-————-—-—--—--——\n”);
学号姓名班级数学英语计算机总成绩\n”);
—-—-——---—-----———--——-----——--—-—-—----——-------——-——-——-—---——---\n"
%—10s%—10s%—10s%-10d%-10d%-10d%-10d\n"
,stu[i].no,stu[i].name,stu[i]。
Class,stu[i].math,stu[i].english,stu[i].computer,stu[i].all);
-—----——---——--——-——--——---—-———-—-—————————-——----—-—-—-----—-—---\n"
5插入学生信息
插入学生信息时,用户输入要插入的位置i,当要插入位置大于结构体成员总数时,直接将数据插入到结构体最后(相当于直接执行输入函数);
当要插入位置小于等于结构体成员总数时,将i~j中的每一项分别向后移动一个位置,再将要插入的数据赋值给第i个位置。
voidInsert()//用户自定义Insert函数,实现将学生信息插入指定位置的功能.
inti,j;
请输入要插入的位置:
scanf(”%d”,&
i);
if(i>
{//当要插入位置大于结构体成员总数时,直接将数据插入到结构体最后。
printf(”输入学生学号:
%s”,stu[n].no);
输入学生姓名:
scanf(”%s"
stu[n].name);
输入学生班级:
%s"
stu[n].Class);
输入学生的数学成绩:
scanf(”%d"
,&stu[n].math);
printf(”输入学生的英语成绩:
scanf(”%d”,&stu[n].english);
输入学生的计算机成绩:
%d”,&stu[n]。
computer);
stu[n]。
all=stu[n]。
math+stu[n]。
english+stu[n].computer;
学生信息输入成功!
}//用户分别输入学生的各项信息,系统返回“输入成功"
的信息。
else
{//当要插入位置不大于结构体成员总数时,执行下述操作.
for(j=n—1;
j>
=i;
j—-)
{
strcpy(stu[j+1]。
no,stu[j]。
no);
strcpy(stu[j+1].name,stu[j].name);
strcpy(stu[j+1].Class,stu[j]。
Class);
stu[j+1]。
math=stu[j].math;
stu[j+1].english=stu[j].english;
stu[j+1]。
computer=stu[j].computer;
stu[j+1]。
all=stu[j]。
}//通过for循环语句,将第j+1项的各项数据赋值给第j项,直到要插入数据的位置为止,实现第i项之后的数据每项都向后移动一个位置。
输入学生学号:
%s”,stu[i].no);
stu[i]。
name);
%s”,stu[i]。
,&
stu[i].math);
”);
scanf(”%d”,&stu[i]。
english);
输入学生的计算机成绩:
stu[i]。
computer);
stu[i]。
all=stu[i]。
math+stu[i]。
english+stu[i]。
printf(”学生信息输入成功!
\n”);
}//将用户输入的各项数据赋值到第i个位置中,实现数据的插入。
n++;
//全局变量n自增1,保证插入的数据存储到结构体中。
6学生信息排序
排序就是通过元素的两两比较,并按照条件,若前一个成员学号值比后一个大,将这二者的所有数据进行交换,使用循环结构重复执行,进行n—1次比较交换后,即完成对结构体中所有成员的排序。
voidRank()
inti,j,p,q,r,y;
charx[20],t[20],w[20];
//定义int型数据和char型数据,用于交换元素值。
正在根据学生学号进行排序,请稍后。
。
n-1;
for(j=0;
j〈n-1-i;
j++)//通过循环结构控制进行n-1次比较交换.
if(strcmp(stu[j].no,stu[j+1].no)〉0)
{//两个字符串的比较,意思是判断前一字符串大于后一字符串。
strcpy(t,stu[j].no);
strcpy(stu[j]。
no,stu[j+1].no);
strcpy(stu[j+1].no,t);
//将stu[j]。
no与stu[j+1]。
no交换。
strcpy(x,stu[j].name);
strcpy(stu[j]。
name,stu[j+1]。
strcpy(stu[j+1]。
name,x);
strcpy(w,stu[j].Class);
Class,stu[j+1].Class);
Class,w);
y=stu[j]。
math;
stu[j]。
math=stu[j+1]。
stu[j+1].math=y;
p=stu[j]。
stu[j].english=stu[j+1]。
english;
stu[j+1]。
english=p;
q=stu[j].computer;
stu[j].computer=stu[j+1]。
computer;
stu[j+1]。
computer=q;
r=stu[j]。
all;
stu[j]。
all=stu[j+1].all;
stu[j+1].all=r;
}//实现第j个成员与第j+1个成员信息的交换。
4.7主函数
voidmain()//无参数无返回值的main函数
for(;
;
)
for(;
;
{//循环语句实现在一项功能执行结束之后菜单函数的重复执行.
intn=0;
switch(menu())
{
case1:
Input();
Output();
break;
//输入1时,调用Input和Output函数。
case2:
Output();
//输入2时,调用Output函数。
case3:
//输入3时,调用Find函数,再次进行功能的选择。
switch(Find())
{
case1:
Findname();
//输入1时,调用Findname函数.
case2:
Findno();
break;
//输入2时,调用Findno函数.
}break;
case4:
Delete();
//输入4时,调用Delete函数。
case5:
Insert();
//输入5时,调用Insert函数。
case6:
Rank();
//输入6时,调用Rank和Output函数.
case0:
exit(0);
//输入7时,调用exit函数,退出程序。
default:
printf("
*输入错误!
*"
//输入不是0~6的字符时,输出“输入错误"
}
}
5调试与测试
系统主界面:
输入学生信息:
输出学生信息:
删除学生信息:
插入学生信息:
查询学生信息:
(按姓名查询)
(按学号查询)
学生信息排序:
6课程设计心得与体会
*******在老师的悉心指导和热心帮助之下,我的C语言课程设计最终顺利完成。
最后,向所有曾经关心和帮助过我的老师以及同学们表示由衷地感谢!
7参考文献
《C语言课程设计实用教程》,谭浩强编,机械工业出版社
《C语言程序设计》,谭浩强编,清华大学出版社
《C程序设计(二级)教程》,谭浩强编,清华大学出版社
8附录
本系统完整程序代码如下:
#include<
stdio。
h>
#include〈string.h>
//文件包含:
关于字符串操作的一些基本函数.
stdlib。
h〉//文件包含:
包含exit()函数。
#defineN80//宏定义:
定义N为80,程序中只进行替换,不进行语法检查.
typedefstruct
charno[11];
charname[8];
charClass[10];
//结构体:
用来储存多名学生的多项信息.
intn=0;
//定义全局变量n,代表结构体中的成员数。
intmenu()//菜单函数,使系统功能以菜单方式工作。
intc;
do{
printf(”\t========学生信息管理系统========\n\n”);
printf(”\t\t1。
输入学生信息\n"
\t\t2。
输出学生信息\n"
\t\t3.查询学生信息\n"
printf(”\t\t4。
删除学生信息\n"
printf(”\t\t5。
插入学生信息\n”);
printf(”\t\t6.学生信息排序\n"
\t\t0。
退出系统\n\n"
printf(”\t请选择:
scanf(”%d"
&c);
}while(c<
0||c〉6);
//当c值小于0或大于6时,循环输出,直到不满足.
return(c);
//返回c值给主调函数,用来选择相应功能。
voidInput()//输入学生信息。
chark,x[10];
k!
=’N’)
scanf(”%s”,stu[n]。
%s”,stu[n].name);
scanf(”%s”,stu[n].Class);
&
stu[n]。
输入学生的英语成绩:
stu[n].english);
scanf(”%d”,&
stu[n].computer);
stu[n].all=stu[n]。
math+stu[n].english+stu[n]。
(Y/N)\n”);
scanf(”%c"
&k);
voidOutput()//输出学生信息。
————---------—-———-—-——--—-—--—-———-—--—-----—-—---—————--—-———————\n”);
printf(”学号姓名班级数学英语计算机总成绩\n”);
printf(”-———---—-—-—-—————------—-—--—--—-——-—--—----—-—--——--——-——-——--—-—\n"
n;
%-10s%—10s%—10s%—10d%—10d%—10d%—10d\n"
name,stu
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言程序设计 学生 成绩管理系统 设计 范本 模板