某班有最多不超过30人(具体人数由实际输入决定)参加期末考试,最多不超过6门(具体门数由实际输入决定)。学生成绩管理系统是一个非常实用的程序,如果能够提前学习字符文件读写操作,把用户输入的数据存盘为字符文件,下次运行时读出,就更有用了。即编程实现如下菜单驱动的学生成绩管理系统:

(1)录入学生的学号、姓名和各科考试成绩;

(2)计算每门课程的总分和平均分;

(3)计算每个学生的总分和平均分;

(4)按每个学生的总分由高到低排出名次表;

(5)按每个学生的总分由低到高排出名次表;

(6)按学号由小到大输出成绩表;

(7)按姓名的字典顺序输出成绩表;

(8)按学号查询学生排名及其考试成绩;

(9)按姓名查询学生排名及其考试成绩;

(10)按优秀(90~100)、良好(80~89)、中等(70~79)、及格(60~69)、不及格(0~59)5个类别,对每门课程分别统计每个类别的人数以及所占的百分比;

(11)输出每个学生的学号、姓名、各科考试成绩,以及每门课程的总分和平均分;

(12)将每个学生的记录信息写入文件(可选实现);

(13)从文件中读出每个学生的记录信息并显示(可选实现)。

要求程序在输入课程门数以及所有课程名称后,先显示如下菜单,并提示用户输入选项:

1.Input record

2.Calculate total and average score of every course

3.Calculate total and average score of every student

4.Sort in descending order by total score of every student

5.Sort in ascending order by total score of every student

6.Sort in ascending order by number

7.Sort in dictionary order by name

8.Search by number

9.Search by name

10.Statistic analysis for every course

11.List record

12.Write to a file

13.Read from a file

0.Exit

Please enter your choice:

然后,根据用户输入的选项执行相应的操作。

注意:12. 13.两项不要求必须实现的。

提示:由于数据输入量较大,而文件操作在同学们完成此次实验(大作业)阶段尚未系统学习,故在不实现12.13.两个菜单项的情况下,为方便程序调试,建议在源程序中采用数组元素初始化的形式提供6-10名学生的数据,以保证程序可以运行调试:

  1. m门课程名称采用字符串数组(字符指针数组)元素初始化;
  2. 采用数组元素初始化方式在源程序中提供6-10位学生的全部信息,每位学生的信息包括姓名、学号以及m门课程成绩(比如:数组长度30,定义数组时初始化前10个元素值);
  3. 程序运行时,选择第1个菜单项录入一个学生的成绩后,相当于学生人数增加1人;
  4. 若选择采用链表实现学生信息的存储,则程序首先将已初始化的数组元素复制到链表实现链式存储后,再启动菜单。
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #define MAX_LEN 10  //* 字符串最大长度 //
    #define STU_NUM 30  //最多的学生人数 //
    #define COURSE_NUM 6 // 最多的考试科目数 *//
    int Menu(void);
    void ReadScore(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], int n, int m);
    void AverSumofEveryStudent(float score[][COURSE_NUM], int n, int m,float sum[STU_NUM], float aver[STU_NUM]);
    void AverSumofEveryCourse(float score[][COURSE_NUM], int n, int m);
    void SortbyScore(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[], float aver[],int n, int m, int (*compare)(float a, float b));
    int Ascending(float a, float b);
    int Descending(float a, float b);
    void SwapFloat(float *x, float *y);
    void SwapLong(long *x, long *y);
    void SwapChar(char x[], char y[]);
    void AsSortbyNum(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[], float aver[],int n, int m);
    void SortbyName(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[], float aver[],int n, int m);
    void SearchbyNum(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[], float aver[],int n, int m);
    void SearchbyName(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[], float aver[],int n, int m);
    void StatisticAnalysis(float score[][COURSE_NUM], int n, int m);
    void PrintScore(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[], float aver[],int n, int m) ;
    int main()
    {char ch;int n = 0, m = 0;float score[STU_NUM][COURSE_NUM], sum[STU_NUM], aver[STU_NUM];long num[STU_NUM];char name[STU_NUM][MAX_LEN];printf("Input student number(n<30):\n", STU_NUM);scanf("%d", &n);while (1){ch = Menu(); // 显示菜单,并读取用户输入 //switch (ch){case 1:printf("Input course number(m<=%d):\n", COURSE_NUM);scanf("%d", &m);ReadScore(num, name, score, n, m);break;case 2:AverSumofEveryCourse(score, n, m);break;case 3:AverSumofEveryStudent(score, n, m, sum, aver);break;case 4:SortbyScore(num, name, score, sum, aver, n, m, Descending);printf("Sort in descending order by score:\n");PrintScore(num, name, score, sum, aver, n, m);break;case 5:SortbyScore(num, name, score, sum, aver, n, m, Ascending);printf("Sort in ascending order by score:\n");PrintScore(num, name, score, sum, aver, n, m);break;case 6:AsSortbyNum(num, name, score, sum, aver, n, m);printf("Sort in ascending order by number:\n");PrintScore(num, name, score, sum, aver, n, m);break;case 7:SortbyName(num, name, score, sum, aver, n, m);printf("Sort in dictionary order by name:\n");PrintScore(num, name, score, sum, aver, n, m);break;case 8:SearchbyNum(num, name, score, sum, aver, n, m);break;case 9:SearchbyName(num, name, score, sum, aver, n, m);break;case 10:StatisticAnalysis(score, n, m);break;case 11:PrintScore(num, name, score, sum, aver, n, m);break;case 0:printf("End of program!");exit(0);default:printf("Input error!\n");}}return 0;
    }
    // 函数功能:显示菜单并获得用户键盘输入的选项 //
    int Menu(void)
    {int itemSelected;printf("Management for Students’ scores\n");printf("1.Input record\n");printf("2.Caculate total and average score of every course\n");printf("3.Caculate total and average score of every student\n");printf("4.Sort in descending order by score\n");printf("5.Sort in ascending order by score\n");printf("6.Sort in ascending order by number\n");printf("7.Sort in dictionary order by name\n");printf("8.Search by number\n");printf("9.Search by name\n");printf("10.Statistic analysis\n");printf("11.List record\n");printf("0.Exit\n");printf("Please Input your choice:\n");scanf("%d", &itemSelected); // 读入用户输入 //return itemSelected;
    }
    // 函数功能:输入n个学生的m门课成绩 //
    void ReadScore(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], int n, int m)
    {int i, j;printf("Input student’s ID, name and score:\n");for (i = 0; i < n; i++){scanf("%ld%s", &num[i], name[i]);for (j = 0; j < m; j++){scanf("%f", &score[i][j]);}}
    }
    // 函数功能:计算每个学生各门课程的总分和平均分 //
    void AverSumofEveryStudent(float score[][COURSE_NUM], int n, int m,float sum[STU_NUM], float aver[STU_NUM])
    {int i, j;for (i = 0; i < n; i++){sum[i] = 0;for (j = 0; j < m; j++){sum[i] = sum[i] + score[i][j];}aver[i] = m > 0 ? sum[i] / m : -1;printf("student %d:sum=%.0f,aver=%.0f\n", i + 1, sum[i], aver[i]);}
    }
    // 函数功能:计算每门课程的总分和平均分 //
    void AverSumofEveryCourse(float score[][COURSE_NUM], int n, int m)
    {int i, j;float sum[COURSE_NUM], aver[COURSE_NUM];for (j = 0; j < m; j++){sum[j] = 0;for (i = 0; i < n; i++){sum[j] = sum[j] + score[i][j];}aver[j] = n > 0 ? sum[j] / n : -1;printf("course %d:sum=%.0f,aver=%.0f\n", j + 1, sum[j], aver[j]);}
    }
    //函数功能:按选择法将数组sum的元素值排序 *//
    void SortbyScore(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[], float aver[],int n, int m, int (*compare)(float a, float b))
    {int i, j, k, t;for (i = 0; i < n - 1; i++){k = i;for (j = i + 1; j < n; j++){if ((compare)(sum[j], sum[k])) k = j;}if (k != i){for (t = 0; t < m; t++) //交换m门课程的成绩 //{SwapFloat(&score[k][t], &score[i][t]);}SwapFloat(&sum[k], &sum[i]); // 交换总分 //SwapFloat(&aver[k], &aver[i]); // 交换平均分 //SwapLong(&num[k], &num[i]); // 交换学号 //SwapChar(name[k], name[i]); // 交换姓名 //}}
    }
    //使数据按升序排序 //
    int Ascending(float a, float b)
    {return a < b; // 这样比较决定了按升序排序,如果a<b,则交换 //
    }
    // 使数据按降序排序 //
    int Descending(float a, float b)
    {return a > b; // 这样比较决定了按降序排序,如果a>b,则交换 //
    }
    // 交换两个单精度浮点型数据 *//
    void SwapFloat(float *x, float *y)
    {float temp;temp = *x;*x = *y;*y = temp;
    }
    // 交换两个长整型数据 *//
    void SwapLong(long *x, long *y)
    {long temp;temp = *x;*x = *y;*y = temp;
    }
    //交换两个字符串 //
    void SwapChar(char x[], char y[])
    {char temp[MAX_LEN];strcpy(temp, x);strcpy(x, y);strcpy(y, temp);
    }
    // 函数功能:按选择法将数组num的元素值按从低到高排序 //
    void AsSortbyNum(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[], float aver[],int n, int m)
    {int i, j, k, t;for (i = 0; i < n - 1; i++){k = i;for (j = i + 1; j < n; j++){if (num[j] < num[k]) k = j;}if (k != i){for (t = 0; t < m; t++) // 交换m门课程的成绩 //{SwapFloat(&score[k][t], &score[i][t]);}SwapFloat(&sum[k], &sum[i]); // 交换总分 //SwapFloat(&aver[k], &aver[i]); // 交换平均分 //SwapLong(&num[k], &num[i]); // 交换学号 //SwapChar(name[k], name[i]); // 交换姓名 //}}
    }
    // 函数功能:交换法实现字符串按字典顺序排序 //
    void SortbyName(long num[], char name[][MAX_LEN], float score[][COURSE_NUM],float sum[], float aver[], int n, int m)
    {int i, j, t;for (i = 0; i < n - 1; i++){for (j = i + 1; j < n; j++){if (strcmp(name[j], name[i]) < 0){for (t = 0; t < m; t++) // 交换m门课程的成绩 //{SwapFloat(&score[i][t], &score[j][t]);}SwapFloat(&sum[i], &sum[j]); // 交换总分 //SwapFloat(&aver[i], &aver[j]); // 交换平均分 //SwapLong(&num[i], &num[j]); // 交换学号 //SwapChar(name[i], name[j]); // 交换姓名 //}}}
    }
    // 函数功能:按学号查找学生成绩并显示查找结果 //
    void SearchbyNum(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[], float aver[],int n, int m)
    {long number;int i, j;printf("Input the number you want to search:\n");scanf("%ld", &number);for (i = 0; i < n; i++){if (num[i] == number){printf("%ld\t%s\t", num[i], name[i]);for (j = 0; j < m; j++){printf("%.0f\t", score[i][j]);}printf("%.0f\t%.0f\n", sum[i], aver[i]);return;}}printf("Not found!\n");
    }
    // 函数功能:按姓名的字典顺序排出成绩表 //
    void SearchbyName(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[], float aver[],int n, int m)
    {char x[MAX_LEN];int i, j;printf("Input the name you want to search:\n");scanf("%s", x);for (i = 0; i < n; i++){if (strcmp(name[i], x) == 0){printf("%ld\t%s\t", num[i], name[i]);for (j = 0; j < m; j++){printf("%.0f\t", score[i][j]);}printf("%.0f\t%.0f\n", sum[i], aver[i]);return;}}printf("Not found!\n");
    }
    // 函数功能:统计各分数段的学生人数及所占的百分比 //
    void StatisticAnalysis(float score[][COURSE_NUM], int n, int m)
    {int i, j, total, t[6];for (j = 0; j < m; j++){printf("For course %d:\n", j + 1);memset(t, 0, sizeof(t)); // 将数组t的全部元素初始化为0 //for (i = 0; i < n; i++){if (score[i][j] >= 0 && score[i][j] < 60) t[0]++;else if (score[i][j] < 70) t[1]++;else if (score[i][j] < 80) t[2]++;else if (score[i][j] < 90) t[3]++;else if (score[i][j] < 100) t[4]++;else if (score[i][j] == 100) t[5]++;}for (total = 0, i = 0; i <= 5; i++){total = total + t[i];}for (i = 0; i <= 5; i++){if (i == 0) printf("<60\t%d\t%.2f%%\n", t[i], (float)t[i] / n * 100);else if (i == 5) printf("%d\t%d\t%.2f%%\n", (i + 5) * 10, t[i], (float)t[i] / n * 100);else printf("%d-%d\t%d\t%.2f%%\n", (i + 5) * 10, (i + 5) * 10 + 9, t[i], (float)t[i] / n * 100);}}
    }
    // 函数功能: 打印学生成绩 *//
    void PrintScore(long num[], char name[][MAX_LEN],float score[][COURSE_NUM], float sum[],float aver[], int n, int m)
    {int i, j;for (i = 0; i < n; i++){printf("%ld\t%s\t", num[i], name[i]);for (j = 0; j < m; j++){printf("%.0f\t", score[i][j]);}printf("%.0f\t%.0f\n", sum[i], aver[i]);}
    }

某班有最多不超过30人(具体人数由实际输入决定)参加期末考试,最多不超过6门(具体门数由实际输入决定)。相关推荐

  1. 完成以下程序,并进行调试某班期末考试科目为数学、英语和计算机,有最多不超过30人参加考试。

    完成以下程序,并进行调试 某班期末考试科目为数学.英语和计算机,有最多不超过30人参加考试,考试后要求:1)计算每个学生的总分和平均分: 2)按总分成绩由高到低排出成绩的名次: 3)打印出名次表,表格 ...

  2. 1、某班期末考试科目为数学(MT)、英语(EN)和物理(PH),有最多不超过30人参加考试。考试后要求:(1)计算每个学生的总分和平均分;(2)按总分成绩由高到低排出成绩的名次;(3)打印出名

    #include<iostream> #include<iomanip> using namespace std; int main() {     int a[30][6], ...

  3. C++程序设计基础,数组实验(题干信息:某班期末考试科目为数学(MT)、英语(EN)和物理(PH),有最多不超30人参加考试,具体问题在下面)

    (1)计算每个学生的总分和平均分: (2)按总分成绩由高到低排出成绩的名次: (3)打印出名次表,表格内包括学生编号.各科分数.总分和平均分: (4)任意输入一个学号,能够查找出该学生在班级中的排名及 ...

  4. 8.4 输入某班学生某门课的成绩,(最多不超过40人,具体人数由用户键盘输入),用函数编程统计不及格人数

    #include<stdio.h> main() { int n,a[40],i,count=0; printf("请输入学生人数:"); scanf("%d ...

  5. 【Tapd】30 人以内团队:申请永久免费的Tapd企业版步骤

    目录 一.前言 二.注册 Tapd 专业版账号 三.配置 Tapd 管理员账号 四.申请 "小微企业扶持计划" 五.开通企业版 一.前言 1.对于新创建的 IT 团队,首先需要选择 ...

  6. 对某班学生成绩排序。从键盘依次输入某班学生的姓名和成绩(一个班级人数最多不超过50人)并保存,然后分别按学生成绩由高到低顺序输出学生姓名和成绩,成绩相同时,则按输入次序排序。

    [问题描述] 对某班学生成绩排序.从键盘依次输入某班学生的姓名和成绩(一个班级人数最多不超过50人)并保存,然后分别按学生成绩由高到低顺序输出学生姓名和成绩,成绩相同时,则按输入次序排序. [输入形式 ...

  7. 某班期末考试科目为数学(MT)、英语(EN)和物理(PH),有最多不超过40人参加考试。请编程计算:(1)每个学生的总分和平均分;(2)每门课程的总分和平均分。

    某班期末考试科目为数学(MT).英语(EN)和物理(PH),有最多不超过40人参加考试.请编程计算:(1)每个学生的总分和平均分:(2)每门课程的总分和平均分. **输入格式要求:"%d&q ...

  8. 清华AI学堂班:姚期智担任首席教授,2019年首批招收30人

    整理 | 琥珀 出品 | AI科技大本营(id:rgznai100) 清华流传一句话,半国英才聚清华,而清华一半英才在"姚班".据不完全统计,自 2005 年开班至今," ...

  9. 首届清华智班30人名单公布:贵校第一批AI本科生,状元金牌云集,与姚班“抢人”...

    鱼羊 乾明 发自 凹非寺  量子位 报道 | 公众号 QbitAI 原来,抢走姚班人才的竟是自家亲兄弟--智班. 清华正式公布了首批智班学生名单,一共30名: 去清华没选姚班的那些奥赛国家集训队选手, ...

最新文章

  1. Linux 背后的思想
  2. Java 分页之最简单的算法
  3. 使用 Azure CLI 2.0 从自定义磁盘创建 Linux VM
  4. 深究AngularJS——排序
  5. java 鉴权_我爱java系列之---【JWT实现微服务鉴权(一)】
  6. 仿生计算(参考神经网络)2017年考试卷子,考前抱佛脚必备!!中英翻译版本!!
  7. Python爬虫xpath详解
  8. java 8 io_Java IO8:IO简单总结
  9. java文件上传maven_ssm+maven框架搭建实现ajax多文件上传功能
  10. BZOJ1298:[SCOI2009]骰子的学问
  11. ROS中阶笔记(十一):ROS 2.0
  12. Kubernetes学习总结(8)—— Kubernetes Pod 资源管理 和 Pod 服务质量
  13. 测试面试题集-Dubbo常见面试题
  14. 十大算法 — 冒泡排序法【C语言代码诠释】
  15. 【原创文章】通过英文电影突破英语
  16. samba端口号修改_samba 端口号(samb端口号)
  17. SQL注入风险与防范措施
  18. ChatGPT团队揭秘:3清华、1北大、1华科
  19. 计算机与人脑的出版社,计算机与人脑
  20. Postman批量提交

热门文章

  1. 关于Linux启动jar包报:Error: Invalid or corrupt xxx.jar问题
  2. 15天的性能优化工作,5方面的调优经验
  3. 干货丨RPA双进程并行技巧
  4. Python爬虫系列之爬取猫眼电影,没办法出门就补一下往期电影吧
  5. 盒子/图片/内容 垂直、水平居中方法总结
  6. RK3568平台开发系列讲解(蓝牙篇)Android 蓝牙框架概览
  7. 格式化或删除的文件 恢复
  8. 北京天宇联科技有限责任公司—智慧园区平台
  9. Tomcat安装注意事项,以及预防各种坑。
  10. PHPExcel 导出的数据Excel打开出现 部分内容有问题是否让我们尽量尝试恢复的问题解决方案