C语言利用结构体数组实现学生成绩管理系统

 更新时间:2018年01月15日 09:57:54   作者:雨晨可爱多  
这篇文章主要为大家详细介绍了C语言利用结构体数组实现学生成绩管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

要求:

某班有最多不超过30人(具体人数由键盘输入)参加期末考试,最多不超过6门(具体门数由键盘输入)。定义结构体类型描述学生信息,每个学生信息包括:学号、姓名、多门课的成绩、总成绩和平均成绩。用结构体数组作为函数参数,编程实现如下菜单驱动的学生成绩管理系统。
(1) 录入每个学生的学号、姓名和各科考试成绩。
(2) 计算每门课程的总分和平均分。
(3) 计算每个学生的总分和平均分。
(4) 按每个学生的总分由高到低排出名次表。
(5) 按学号由小到大排出成绩表。
(6) 按姓名的字典顺序排出成绩表。
(7) 按学号查询学生排名极其考试成绩。
(8) 按姓名查询学生排名极其考试成绩。
(9) 按优秀(90~100)、良好(80~90)、中等(70~80)、及格(60~70)、不及格(0~59)5个类别,对每门课程分别统计每个类别的人数以及所占的百分比。
(10) 输出每个学生的学号、姓名、各科考试成绩以及每门课程的总分和平均分。

代码:

#include<stdio.h>
#include<Windows.h>
#include<conio.h>

#define SN 30 //学生人数
#define CN 6 //科目数
#define NL 20 //名字字节长度

typedef struct student{
 long int num;
 char name[NL];
 float score[CN];
 float sum;
 float aver;
}STU;

STU s[SN];
int itemSelected=-1;
int n=0;//学生数
int m=0;//课程数

int Menu();//菜单
void chose(int itemSelected);//选择
void inputScore();//输入分数
void AverofC();//计算每门课程平均数
void AverofS();//每名学生总分和平均分
void sortByNum();//学生总分排行
void sortByGrade();
void sortByName();
void findByNum();
void findByName();
void statisticsAnalysis();
void printScore();

void main(){
 printf("请输入学生总数(n<%d):\n",SN);
 scanf("%d",&n);
 printf("请输入课程总数(m<%d):\n",CN);
 scanf("%d",&m);
 while(1){
 itemSelected=Menu();
 chose(itemSelected);
 itemSelected=-1;
 }
}

int Menu(){
 int itemSelected;
 system("cls");
 printf("\n ==============学生成绩管理系统===============\n");
 printf("\t 1.输入学号、姓名及各科成绩\n");
 printf("\t 2.计算每门课程总分和平均分\n");
 printf("\t 3.计算每个学生总分和平局分\n");
 printf("\t 4.按每个学生总分高低排出名次表\n");
 printf("\t 5.按学号从小到大排出成绩表\n");
 printf("\t 6.按学生字典顺序排出成绩表\n");
 printf("\t 7.按学号查询学生排名和考试成绩\n");
 printf("\t 8.按姓名查询学生排名和成绩\n");
 printf("\t 9.结果分析\n");
 printf("\t 10.输出信息\n");
 printf("\t 0.退出\n");
 printf("===============================================\n");
 printf("请选择选项:");
 scanf("%d",&itemSelected);
 return itemSelected;
}

void chose(int itemSelected){
 switch(itemSelected){
 case 1: inputScore(); break;
 case 2: AverofC();break;
 case 3: AverofS();break;
 case 4: sortByGrade();break;
 case 5: sortByNum();break;
 case 6: sortByName();break;
 case 7: findByNum();break;
 case 8: findByName();break;
 case 9: statisticsAnalysis();break;
 case 10: printScore();break;
 case 0: exit(0);
 printf("即将退出程序");break;
 default: printf("输入错误!");break;
 }
}

void inputScore(){
 printf("\n===============================================\n");
 printf("请输入学生学号、姓名及各科信息(输入0停止信息输入)\n");
 for(int i=0;i<n;i++){
 printf("学号(8位)");
 scanf("%ld",&s[i].num);
 if(s[i].num==0) break;
 getchar();//吸收多余换行符
 printf("姓名");
 gets(s[i].name);
 printf("请输入各科成绩");
 s[i].sum=0;
 for(int j =0;j<m;j++){
  scanf("%f",&s[i].score[j]);
  s[i].sum +=s[i].score[j];
 }
 }
}

void AverofC(){
 float sum[CN]={0};
 float average[CN]={0};
 for(int i=0;i<m;i++){
 for(int j=0;j<n;j++){
 sum[i]+=s[j].score[i];
 }
 average[i]=sum[i]/n;
 printf("第%d门课程的总分为:%.2f,平均分为%.2f\n",i+1,sum[i],average[i]);
 } 
 getch();
}

void AverofS(){
 float sum[SN]={0};
 float average[SN]={0};
 for (int i=0;i<n;i++){
 for(int j=0;j<m;j++){
  sum[i]+=s[i].score[j];
 }
 average[i]=sum[i]/m;
 printf("第%d个学生的总分为:%.2f,平均分为%.2f\n",i+1,sum[i],average[i]);
 }
 getch();
}

void sortByNum(){
 //按学号从小到大排序
 STU temp1={0};
 for(int i=0;i<n-1;i++){
 if(s[i].num>s[i+1].num){
  temp1=s[i];
  s[i]=s[i+1];
  s[i+1]=temp1;
 }
 }
 printf("\n==============按学号从小到排序===============\n");
 for(int j=0;j<n;j++){
 printf("该学生的学号为:%d\n",s[j].num);
 printf("该学生的姓名为:");
 for(int k=0;k<NL;k++){
  printf("%c",s[j].name[k]);
 }
 printf("\n该学生的各科成绩为\n");
 for(int c=0;c<m;c++){
  printf("第%d门成绩为%.2f\n",c+1,s[j].score[c]);
 }
 printf("\n");
 }
 getch();
}

void sortByGrade(){
 //按总分从高到低排序
 STU temp1={0};
 for(int i=0;i<n-1;i++){
  if(s[i].sum<s[i+1].sum){
  temp1=s[i];
  s[i]=s[i+1];
  s[i+1]=temp1;
 }
 }
 printf("\n============按总成绩从高到低排序===========\n");
 for(int j=0;j<n;j++){
 printf("该学生的学号为:%d\n",s[j].num);
 printf("该学生的姓名为:");
 for(int k=0;k<NL;k++){
  printf("%c",s[j].name[k]);
 }
 printf("\n该学生的各科成绩为\n");
 for(int c=0;c<m;c++){
  printf("第%d门成绩为%.2f\n",c+1,s[j].score[c]);
 }
 printf("该学生的总成绩为:%.2f",s[j].sum);
 printf("\n");
 }
 getch();
}

void sortByName(){
 //按姓名首字母字典顺序排序
 STU temp1={0}; 
 for(int i=0;i<n-1;i++){
  if(((int)(s[i].name[0])>(int)(s[i+1].name[0]))){
  //将名字首字母转成成ASCII码从而比较大小排序
  temp1=s[i];
  s[i]=s[i+1];
  s[i+1]=temp1;
 }
 }
 printf("\n==============按学号从小到排序===============\n");
 for(int j=0;j<n;j++){
 printf("该学生的学号为:%d\n",s[j].num);
 printf("该学生的姓名为:");
 for(int k=0;k<NL;k++){
  printf("%c",s[j].name[k]);
 }
 printf("\n该学生的各科成绩为\n");
 for(int c=0;c<m;c++){
  printf("第%d门成绩为%.2f\n",c+1,s[j].score[c]);
 }
 printf("该学生的总成绩为:%.2f",s[j].sum);
 printf("\n");
 }
 getch();
}

void findByNum() {
 int find=-1;
 //记录需要查找的学号,并作为查找成功与否的标识符
 printf("请输入要查找的学号:");
 scanf("%d",&find);
 for(int i=0;i<n;i++){
 if(s[i].num==find){
  printf("\n查找成功\n");
  printf("该学生的学号为%d\n",s[i].num);
  printf("该学生的姓名为:");
  for(int k=0;k<NL;k++){
  printf("%c",s[i].name[k]);
  }
  printf("\n该学生的各科成绩为\n");
  for(int c=0;c<m;c++){
  printf("第%d门成绩为%.2f\n",c+1,s[i].score[c]);
  }
  printf("该学生的总成绩为:%.2f",s[i].sum);
  printf("\n");
  find=-2;
 }
 }
 if(find!=-2){
 printf("查无此人\n");
 printf("按任意键继续");
 }
 getch();
}

void findByName(){
 int is_find=0;
 char find[SN];
 printf("请输入要查找的姓名:");
 getchar();
 gets(find);
 for(int i=0;i<n;i++){
 if(strcmp(s[i].name,find)==0){
  printf("\n查找成功\n");
  printf("该学生的学号为%d\n",s[i].num);
  printf("该学生的姓名为:");
  for(int k=0;k<NL;k++){
  printf("%c",s[i].name[k]);
  }
  printf("\n该学生的各科成绩为\n");
  for(int c=0;c<m;c++){
  printf("第%d门成绩为%.2f\n",c+1,s[i].score[c]);
  }
  printf("该学生的总成绩为:%.2f",s[i].sum);
  printf("\n");
  is_find=1;
 }
 }
 if(is_find!=1){
 printf("查无此人\n");
 printf("按任意键继续");
 }
 getch();
}

void statisticsAnalysis(){
 printf("输出每门课程优秀、良好、中等、及格、不及格人数所占的百分比\n");
 int a1[CN]={0},a2[CN]={0},a3[CN]={0},a4[CN]={0},a5[CN]={0};
 for(int i=0;i<n;i++){
 for(int j=0;j<m;j++){
  if(s[i].score[j]>=90 && s[i].score[j]<=100){
  a1[j]++;
  }else if (s[i].score[j]>=80 && s[i].score[j]<90){
  a2[j]++;
  }else if (s[i].score[j]>=70 && s[i].score[j]<80){
  a3[j]++;
  }else if (s[i].score[j]>=60 && s[i].score[j]<70){
  a4[j]++;
  }else if (s[i].score[j]<60){
  a5[j]++;
  }
 }
 }
 printf("\n====================各们课程概况==================\n");
 for(int k=0;k<m;k++){
  printf("第%d门课的优秀人数占%.2f%%,",k+1,(a1[k]/(n*1.0))*100);
  printf("良好人数占%.2f%%,",(a2[k]/(n*1.0))*100);
  printf("中等人数占%.2f%%,",(a3[k]/(n*1.0))*100);
  printf("及格人数占%.2f%%,",(a4[k]/(n*1.0))*100);
  printf("不及格人数占%.2f%%,",(a5[k]/(n*1.0))*100);

  printf("\n");
 }
 getch();
}

void printScore(){
 printf("==============以下为学生信息==============");
 for(int j=0;j<n;j++){
 printf("该学生的学号为:%d\n",s[j].num);
 printf("该学生的姓名为:");
 for(int k=0;k<NL;k++){
  printf("%c",s[j].name[k]);
 }
 printf("\n该学生的各科成绩为\n");
 for(int c=0;c<m;c++){
  printf("第%d门成绩为%.2f\n",c+1,s[j].score[c]);
 }
 printf("该学生的总成绩为:%.2f",s[j].sum);
 printf("\n");
 }
 getch();
}

更多学习资料请关注专题《管理系统开发》。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C语言快速排序函数用法(qsort)

    C语言快速排序函数用法(qsort)

    这篇文章主要为大家详细介绍了C语言的快排函数用法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • C++中的STL常用算法之遍历算法详解

    C++中的STL常用算法之遍历算法详解

    这篇文章主要介绍了C++中的STL常用算法之遍历算法详解,ransform() 可以将函数应用到容器的元素上,并将这个函数返回的值保存到另一个容器中,它返回的迭代器指向输出容器所保存的最后一个元素的下一个位置,需要的朋友可以参考下
    2023-12-12
  • C语言与C++中关于字符串使用的比较

    C语言与C++中关于字符串使用的比较

    字符串是我们再熟悉不过的东西了,任何语言中字符串都是基础都要经常用到,那么在不同语言中字符串的用法一样吗?下面我们来看看C语言与C++中字符串使用的比较
    2022-05-05
  • 使用OpenGL绘制Bezier曲线

    使用OpenGL绘制Bezier曲线

    这篇文章主要为大家详细介绍了使用OpenGL绘制Bezier曲线的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • C++面试题之数a、b的值互换(不使用中间变量)

    C++面试题之数a、b的值互换(不使用中间变量)

    这篇文章主要介绍了不使用中间变量,C++实现数a、b的值互相转换操作,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • C语言 structural body结构体详解用法

    C语言 structural body结构体详解用法

    C 数组允许定义可存储相同类型数据项的变量,结构是 C 编程中另一种用户自定义的可用的数据类型,它允许您存储不同类型的数据项,结构用于表示一条记录,假设您想要跟踪图书馆中书本的动态,您可能需要跟踪每本书的下列属性
    2021-10-10
  • C语言实现简单停车场管理系统

    C语言实现简单停车场管理系统

    这篇文章主要为大家详细介绍了C语言实现简单停车场管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • OpenCV c++滑动条的创建和使用代码

    OpenCV c++滑动条的创建和使用代码

    滚动条(Trackbar)在OpenCV中是非常方便的交互工具,它依附于特定的窗口而存在,下面这篇文章主要给大家介绍了关于OpenCV c++滑动条的创建和使用的相关资料,需要的朋友可以参考下
    2023-06-06
  • C语言实现二叉树的搜索及相关算法示例

    C语言实现二叉树的搜索及相关算法示例

    这篇文章主要介绍了C语言实现二叉树的搜索及相关算法,结合具体实例形式分析了基于C语言创建、遍历、搜索等相关算法与实现技巧,需要的朋友可以参考下
    2017-06-06
  • C语言实现双人反弹球游戏

    C语言实现双人反弹球游戏

    这篇文章主要为大家详细介绍了C语言实现双人反弹球游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05

最新评论