
C语言学生成绩管理系统的设计
学生成绩管理系统设计一个学生成绩管理系统,对上学期的本班的学习成绩进行管理,可以用数组来设计这个程序,具有查询和检索功能,并且能够对指定文件操作,也可将多个文件组成一个文...
学生成绩管理系统
设计一个学生成绩管理系统,对上学期的本班的学习成绩进行管理,可以用数组来设计这个程序,具有查询和检索功能,并且能够对指定文件操作,也可将多个文件组成一个文件。
1、设计内容
1) 每一条记录包括一个学生的学号、姓名、性别、各门课成绩(上学期的科目)、平均成绩。
2) 输入功能:可以一次完成若干条记录的输入。
3) 显示功能:完成全部学生记录的显示。
4) 查找功能:完成按姓名或学号查找学生记录,并显示。
5) 排序功能:按学生平均成绩进行排序。
6) 插入功能:按平均成绩高低插入一条学生记录。
7) 将学生记录存在文件student.dat中。
8) 应提供一个界面来调用各个功能,调用界面和各个功能的操作界面应尽可能清晰美观!
2、设计要求
已知有存储本班学生记录(包括学号、姓名、科目成绩、性别、)的文件student.dat,所有学生以学号从小到大排序(该文件自行建立)。要求编程序实现查询、排序、插入、删除诸功能。具体要求如下:
1) 要求显示如下界面
a) ****************************************
a) 1--------------查询
b) 2--------------排序
c) 3--------------插入
d) 4--------------删除
b) ****************************************
c) 通过选择1-4来确定要做哪一个操作。
2) 若选1,则出现如下界面
a) ****************************************
a) 1.1----------按学号查询
b) 1.2----------按姓名查询
c) 1.3----------按成绩查询
b) ****************************************
c) 通过选择1.1-1.3来确定要做哪一个操作,其中:按姓名查询用顺序法实现;按成绩查询实现查询成绩小于m分的学生;找到该生将学生记录输出到屏幕,若查无此人,输出相关信息。
3) 若选2,则按成绩从大到小排序,姓名,学号顺序也随之调整。
4) 若选3,将一个新学生记录按学号顺序插入,并把结果保存到文件student.dat中。
5) 若选4,删除指定学生的记录,并把结果保存到文件student.dat中。
6) 不同的模块都要有出错处理,并能给出出错提示。如输入数据错误,文件操作错误等等
7) 以上各个功能均编写成子函数,由主函数调用实现。
8) 利用结构体数组实现学生成绩的数据结构设计; 展开
设计一个学生成绩管理系统,对上学期的本班的学习成绩进行管理,可以用数组来设计这个程序,具有查询和检索功能,并且能够对指定文件操作,也可将多个文件组成一个文件。
1、设计内容
1) 每一条记录包括一个学生的学号、姓名、性别、各门课成绩(上学期的科目)、平均成绩。
2) 输入功能:可以一次完成若干条记录的输入。
3) 显示功能:完成全部学生记录的显示。
4) 查找功能:完成按姓名或学号查找学生记录,并显示。
5) 排序功能:按学生平均成绩进行排序。
6) 插入功能:按平均成绩高低插入一条学生记录。
7) 将学生记录存在文件student.dat中。
8) 应提供一个界面来调用各个功能,调用界面和各个功能的操作界面应尽可能清晰美观!
2、设计要求
已知有存储本班学生记录(包括学号、姓名、科目成绩、性别、)的文件student.dat,所有学生以学号从小到大排序(该文件自行建立)。要求编程序实现查询、排序、插入、删除诸功能。具体要求如下:
1) 要求显示如下界面
a) ****************************************
a) 1--------------查询
b) 2--------------排序
c) 3--------------插入
d) 4--------------删除
b) ****************************************
c) 通过选择1-4来确定要做哪一个操作。
2) 若选1,则出现如下界面
a) ****************************************
a) 1.1----------按学号查询
b) 1.2----------按姓名查询
c) 1.3----------按成绩查询
b) ****************************************
c) 通过选择1.1-1.3来确定要做哪一个操作,其中:按姓名查询用顺序法实现;按成绩查询实现查询成绩小于m分的学生;找到该生将学生记录输出到屏幕,若查无此人,输出相关信息。
3) 若选2,则按成绩从大到小排序,姓名,学号顺序也随之调整。
4) 若选3,将一个新学生记录按学号顺序插入,并把结果保存到文件student.dat中。
5) 若选4,删除指定学生的记录,并把结果保存到文件student.dat中。
6) 不同的模块都要有出错处理,并能给出出错提示。如输入数据错误,文件操作错误等等
7) 以上各个功能均编写成子函数,由主函数调用实现。
8) 利用结构体数组实现学生成绩的数据结构设计; 展开
3个回答
展开全部
#include<stdio.h>
#define N 40
#include<string.h>
struct student{
long num;
char name[10];
float score[5];
int number[6][6];
float sum;
};
void menu()
{
printf(" ****************************************\n");
printf(" 1--------------查询\n");
printf(" 2--------------排序\n");
printf(" 3--------------插入\n 4--------------删除\n");
printf(" 0--------------退出\n");
printf(" ****************************************\n");
}
void input(struct student s[],int *n)
{
printf("please intput the number of the student you want to add\n");
int x,i,j,b,flag=0;
scanf("%d",&x);
b=*n+x;
for(i=*n+1;i<=b;i++)
{
flag=1;
scanf("%ld",&s[i].num);
for(j=1;j<i;j++)
if(s[i].num==s[j].num&&i>1)
{ printf("input error\n");flag=0;i--;b--;break;}
if(flag)
{
scanf("%s",s[i].name);
for(j=1;j<=5;j++)
scanf("%f",&s[i].score[j]);
}
}
*n=b;if(flag) printf("添加成功\n");
}
void Delete(struct student s[],int *n)
{
printf("please input the name of the student you want to delete\n");
char m[10];int j;
scanf("%s",m);
for(j=1;j<=*n;j++)
if(strcmp(s[j].name,m)==0)
{
*n=*n-1;
for(;j<=*n;j++)
s[j]=s[j+1];
break;
}
printf("Delete succeed!\n");
}
void find(struct student s[],int n)
{
long b=0;char c[10],kk[10];
printf(" ****************************************\n");
printf(" 1.1----------按学号查询\n");
printf(" 1.2----------按姓名查询\n");
printf(" 1.3----------按成绩查询\n");
printf(" ****************************************\n");
int j,e;
float soc;
scanf("%s",kk);
if(strcmp(kk,"1.1/0")==0){
printf("请输入学生学号\n");
scanf("%s",c);
{
for(j=0,e=strlen(c);j<e;j++)
b=b*10+c[j]-48;
printf("学号\t姓名\t高数\t英语读写 英语听说 计导 程序(一) 总分\n");
for(j=1;j<=n;j++)
if(b==s[j].num)
{
printf("%ld\t%s\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\n",s[j].num,s[j].name,s[j].score[1],s[j].score[2],s[j].score[3],s[j].score[4],s[j].score[5],s[j].sum);
}
}
}
else if(strcmp(kk,"1.2")==0)
{
printf("请输入学生姓名\n");
scanf("%s",c);
printf("学号\t姓名\t高数\t英语读写 英语听说 计导 程序(一) 总分\n");
for(j=1;j<=n;j++)
if(strcmp(s[j].name,c)==0)
{
printf("%ld\t%s\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\n",s[j].num,s[j].name,s[j].score[1],s[j].score[2],s[j].score[3],s[j].score[4],s[j].score[5],s[j].sum);
}
}
else
{
printf("请输入学生分数\n");
scanf("%f",&soc);
printf("学号\t姓名\t高数\t英语读写 英语听说 计导 程序(一) 总分\n");
for(j=1;j<=n;j++)
if(s[j].sum==soc)
{
printf("%ld\t%s\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\n",s[j].num,s[j].name,s[j].score[1],s[j].score[2],s[j].score[3],s[j].score[4],s[j].score[5],s[j].sum);
}
}
}
void sort(struct student s[],int n)
{
int j,f,g,h;
for(j=1;j<=5;j++)
for(h=1;h<=5;h++)
s[0].number[j][h]=0;
for(j=1;j<=n;j++)
for(f=1,s[j].sum=0;f<=5;f++)
s[j].sum=s[j].sum+s[j].score[f];
for(f=1;f<=5;f++)
for(g=1;g<=n;g++)
if(s[g].score[f]>=90)
s[0].number[f][5]++;
else if(s[g].score[f]>=80&&s[g].score[f]<90)
s[0].number[f][4]++;
else if(s[g].score[f]>=70&&s[g].score[f]<80)
s[0].number[f][3]++;
else if(s[g].score[f]>=60&&s[g].score[f]<70)
s[0].number[f][2]++;
else
s[0].number[f][1]++;
struct student temp;
for(j=1;j<n;j++)
for(g=1;g<=n-j;g++)
if(s[g].sum>s[g+1].sum )
{
temp=s[g];
s[g]=s[g+1];
s[g+1]=temp;
}
}
void print1(struct student s[],int n)
{
printf("学号\t姓名\t高数\t英语读写 英语听说 计导 程序(一) 总分\n");
for(;n>0;n--)
printf("%ld\t%s\t%-0.2f\t%0.2f\t %0.2f\t %0.2f\t %0.2f\t %0.2f\n",s[n].num,s[n].name,s[n].score[1],s[n].score[2],s[n].score[3],s[n].score[4],s[n].score[5],s[n].sum );
}
int main()
{
menu();
int x,n=0;
struct student stu[N];
while(scanf("%d",&x)!=EOF&&x!=0)
{
switch(x)
{
case 1:find(stu,n);break;
case 2:sort(stu,n);print1(stu,n);break;
case 3:input(stu,&n);sort(stu,n);break;
case 4:Delete(stu,&n);break;
default:printf("Input error!\n");
}
}
return 0;
}
注:
(1)在插入的时候,先是输入添加的学生个数,按回车之后分别输入学生的学号、姓名、高数成绩、英语读写成绩、英语听说成绩、计算机导论、程序设计成绩
(2)在删除时,可以输入学生的姓名或者学号
#define N 40
#include<string.h>
struct student{
long num;
char name[10];
float score[5];
int number[6][6];
float sum;
};
void menu()
{
printf(" ****************************************\n");
printf(" 1--------------查询\n");
printf(" 2--------------排序\n");
printf(" 3--------------插入\n 4--------------删除\n");
printf(" 0--------------退出\n");
printf(" ****************************************\n");
}
void input(struct student s[],int *n)
{
printf("please intput the number of the student you want to add\n");
int x,i,j,b,flag=0;
scanf("%d",&x);
b=*n+x;
for(i=*n+1;i<=b;i++)
{
flag=1;
scanf("%ld",&s[i].num);
for(j=1;j<i;j++)
if(s[i].num==s[j].num&&i>1)
{ printf("input error\n");flag=0;i--;b--;break;}
if(flag)
{
scanf("%s",s[i].name);
for(j=1;j<=5;j++)
scanf("%f",&s[i].score[j]);
}
}
*n=b;if(flag) printf("添加成功\n");
}
void Delete(struct student s[],int *n)
{
printf("please input the name of the student you want to delete\n");
char m[10];int j;
scanf("%s",m);
for(j=1;j<=*n;j++)
if(strcmp(s[j].name,m)==0)
{
*n=*n-1;
for(;j<=*n;j++)
s[j]=s[j+1];
break;
}
printf("Delete succeed!\n");
}
void find(struct student s[],int n)
{
long b=0;char c[10],kk[10];
printf(" ****************************************\n");
printf(" 1.1----------按学号查询\n");
printf(" 1.2----------按姓名查询\n");
printf(" 1.3----------按成绩查询\n");
printf(" ****************************************\n");
int j,e;
float soc;
scanf("%s",kk);
if(strcmp(kk,"1.1/0")==0){
printf("请输入学生学号\n");
scanf("%s",c);
{
for(j=0,e=strlen(c);j<e;j++)
b=b*10+c[j]-48;
printf("学号\t姓名\t高数\t英语读写 英语听说 计导 程序(一) 总分\n");
for(j=1;j<=n;j++)
if(b==s[j].num)
{
printf("%ld\t%s\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\n",s[j].num,s[j].name,s[j].score[1],s[j].score[2],s[j].score[3],s[j].score[4],s[j].score[5],s[j].sum);
}
}
}
else if(strcmp(kk,"1.2")==0)
{
printf("请输入学生姓名\n");
scanf("%s",c);
printf("学号\t姓名\t高数\t英语读写 英语听说 计导 程序(一) 总分\n");
for(j=1;j<=n;j++)
if(strcmp(s[j].name,c)==0)
{
printf("%ld\t%s\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\n",s[j].num,s[j].name,s[j].score[1],s[j].score[2],s[j].score[3],s[j].score[4],s[j].score[5],s[j].sum);
}
}
else
{
printf("请输入学生分数\n");
scanf("%f",&soc);
printf("学号\t姓名\t高数\t英语读写 英语听说 计导 程序(一) 总分\n");
for(j=1;j<=n;j++)
if(s[j].sum==soc)
{
printf("%ld\t%s\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\t%-0.2f\n",s[j].num,s[j].name,s[j].score[1],s[j].score[2],s[j].score[3],s[j].score[4],s[j].score[5],s[j].sum);
}
}
}
void sort(struct student s[],int n)
{
int j,f,g,h;
for(j=1;j<=5;j++)
for(h=1;h<=5;h++)
s[0].number[j][h]=0;
for(j=1;j<=n;j++)
for(f=1,s[j].sum=0;f<=5;f++)
s[j].sum=s[j].sum+s[j].score[f];
for(f=1;f<=5;f++)
for(g=1;g<=n;g++)
if(s[g].score[f]>=90)
s[0].number[f][5]++;
else if(s[g].score[f]>=80&&s[g].score[f]<90)
s[0].number[f][4]++;
else if(s[g].score[f]>=70&&s[g].score[f]<80)
s[0].number[f][3]++;
else if(s[g].score[f]>=60&&s[g].score[f]<70)
s[0].number[f][2]++;
else
s[0].number[f][1]++;
struct student temp;
for(j=1;j<n;j++)
for(g=1;g<=n-j;g++)
if(s[g].sum>s[g+1].sum )
{
temp=s[g];
s[g]=s[g+1];
s[g+1]=temp;
}
}
void print1(struct student s[],int n)
{
printf("学号\t姓名\t高数\t英语读写 英语听说 计导 程序(一) 总分\n");
for(;n>0;n--)
printf("%ld\t%s\t%-0.2f\t%0.2f\t %0.2f\t %0.2f\t %0.2f\t %0.2f\n",s[n].num,s[n].name,s[n].score[1],s[n].score[2],s[n].score[3],s[n].score[4],s[n].score[5],s[n].sum );
}
int main()
{
menu();
int x,n=0;
struct student stu[N];
while(scanf("%d",&x)!=EOF&&x!=0)
{
switch(x)
{
case 1:find(stu,n);break;
case 2:sort(stu,n);print1(stu,n);break;
case 3:input(stu,&n);sort(stu,n);break;
case 4:Delete(stu,&n);break;
default:printf("Input error!\n");
}
}
return 0;
}
注:
(1)在插入的时候,先是输入添加的学生个数,按回车之后分别输入学生的学号、姓名、高数成绩、英语读写成绩、英语听说成绩、计算机导论、程序设计成绩
(2)在删除时,可以输入学生的姓名或者学号
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |