依星源码资源网,依星资源网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

【好消息,好消息,好消息】VIP会员可以发表文章赚积分啦 !
查看: 738|回复: 1

学生成绩管理系统C++语言

[复制链接] 主动推送

1万

主题

1万

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
12858
发表于 2024-1-8 11:34:22 | 显示全部楼层 |阅读模式
学生成绩管理系统C++语言,编程要求:
1)学生基本信息及成绩所选科目成绩的录入。
2)基本信息的查询(分系、班级;分科目)与修改。
3)对每系或每班各科成绩进行分析(即求单科平均成绩、及格率和优秀率);
4)对所开课程的成绩分析(求其平均成绩,最高分和最低分);
5)对学生考试成绩进行排名(单科按系别或班级进行排名,对每一个班级,同一学期学生总体成绩进行排名,并显示各科成绩信息)
以下是一个简单的学生成绩管理系统的C++代码示例,满足您的编程要求:
  1. #include <iostream>
  2. #include <string>
  3. #include <vector>
  4. #include <algorithm>
  5. using namespace std;
  6. // 学生类
  7. class Student {
  8. private:
  9.     string name;
  10.     string department;
  11.     string className;
  12.     vector<int> scores;
  13. public:
  14.     // 构造函数
  15.     Student(string name, string department, string className) {
  16.         this->name = name;
  17.         this->department = department;
  18.         this->className = className;
  19.     }
  20.      // 添加成绩
  21.     void addScore(int score) {
  22.         scores.push_back(score);
  23.     }
  24.      // 获取平均成绩
  25.     float getAverageScore() {
  26.         int sum = 0;
  27.         for (int score : scores) {
  28.             sum += score;
  29.         }
  30.         return static_cast<float>(sum) / scores.size();
  31.     }
  32.      // 获取及格率
  33.     float getPassRate() {
  34.         int passCount = count_if(scores.begin(), scores.end(), [](int score) {
  35.             return score >= 60;
  36.         });
  37.         return static_cast<float>(passCount) / scores.size() * 100;
  38.     }
  39.      // 获取优秀率
  40.     float getExcellentRate() {
  41.         int excellentCount = count_if(scores.begin(), scores.end(), [](int score) {
  42.             return score >= 90;
  43.         });
  44.         return static_cast<float>(excellentCount) / scores.size() * 100;
  45.     }
  46.      // 获取学生姓名
  47.     string getName() {
  48.         return name;
  49.     }
  50.      // 获取系别
  51.     string getDepartment() {
  52.         return department;
  53.     }
  54.      // 获取班级
  55.     string getClassName() {
  56.         return className;
  57.     }
  58.      // 获取成绩
  59.     vector<int> getScores() {
  60.         return scores;
  61.     }
  62. };
  63. // 学生成绩管理系统类
  64. class GradeManagementSystem {
  65. private:
  66.     vector<Student> students;
  67. public:
  68.     // 添加学生
  69.     void addStudent(Student student) {
  70.         students.push_back(student);
  71.     }
  72.      // 根据系别和班级查询学生
  73.     vector<Student> searchByDepartmentAndClass(string department, string className) {
  74.         vector<Student> result;
  75.         for (const auto& student : students) {
  76.             if (student.getDepartment() == department && student.getClassName() == className) {
  77.                 result.push_back(student);
  78.             }
  79.         }
  80.         return result;
  81.     }
  82.      // 根据科目查询学生成绩
  83.     vector<int> searchScoresBySubject(string subject) {
  84.         vector<int> result;
  85.         for (const auto& student : students) {
  86.             // 假设每个学生的科目成绩顺序相同,可以通过索引来获取对应科目的成绩
  87.             int index = -1;
  88.             if (subject == "Math") {
  89.                 index = 0;
  90.             } else if (subject == "English") {
  91.                 index = 1;
  92.             } else if (subject == "Physics") {
  93.                 index = 2;
  94.             }
  95.             if (index >= 0 && index < student.getScores().size()) {
  96.                 result.push_back(student.getScores()[index]);
  97.             }
  98.         }
  99.         return result;
  100.     }
  101.      // 分析每系或每班各科成绩
  102.     void analyzeScoresByDepartmentOrClass(string department, string className) {
  103.         vector<Student> studentsToAnalyze = searchByDepartmentAndClass(department, className);
  104.         if (studentsToAnalyze.empty()) {
  105.             cout << "No students found in the specified department and class." << endl;
  106.             return;
  107.         }
  108.          // 计算单科平均成绩、及格率和优秀率
  109.         float mathAverage = 0, englishAverage = 0, physicsAverage = 0;
  110.         float mathPassRate = 0, englishPassRate = 0, physicsPassRate = 0;
  111.         float mathExcellentRate = 0, englishExcellentRate = 0, physicsExcellentRate = 0;
  112.         int studentCount = studentsToAnalyze.size();
  113.          for (const auto& student : studentsToAnalyze) {
  114.             mathAverage += student.getScores()[0];
  115.             englishAverage += student.getScores()[1];
  116.             physicsAverage += student.getScores()[2];
  117.              if (student.getScores()[0] >= 60) {
  118.                 mathPassRate++;
  119.             }
  120.             if (student.getScores()[1] >= 60) {
  121.                 englishPassRate++;
  122.             }
  123.             if (student.getScores()[2] >= 60) {
  124.                 physicsPassRate++;
  125.             }
  126.              if (student.getScores()[0] >= 90) {
  127.                 mathExcellentRate++;
  128.             }
  129.             if (student.getScores()[1] >= 90) {
  130.                 englishExcellentRate++;
  131.             }
  132.             if (student.getScores()[2] >= 90) {
  133.                 physicsExcellentRate++;
  134.             }
  135.         }
  136.          mathAverage /= studentCount;
  137.         englishAverage /= studentCount;
  138.         physicsAverage /= studentCount;
  139.         mathPassRate = mathPassRate / studentCount * 100;
  140.         englishPassRate = englishPassRate / studentCount * 100;
  141.         physicsPassRate = physicsPassRate / studentCount * 100;
  142.         mathExcellentRate = mathExcellentRate / studentCount * 100;
  143.         englishExcellentRate = englishExcellentRate / studentCount * 100;
  144.         physicsExcellentRate = physicsExcellentRate / studentCount * 100;
  145.          // 输出分析结果
  146.         cout << "Analysis for Department: " << department << ", Class: " << className << endl;
  147.         cout << "Math Average: " << mathAverage << endl;
  148.         cout << "Math Pass Rate: " << mathPassRate << "%" << endl;
  149.         cout << "Math Excellent Rate: " << mathExcellentRate << "%" << endl;
  150.         cout << "English Average: " << englishAverage << endl;
  151.         cout << "English Pass Rate: " << englishPassRate << "%" << endl;
  152.         cout << "English Excellent Rate: " << englishExcellentRate << "%" << endl;
  153.         cout << "Physics Average: " << physicsAverage << endl;
  154.         cout << "Physics Pass Rate: " << physicsPassRate << "%" << endl;
  155.         cout << "Physics Excellent Rate: " << physicsExcellentRate << "%" << endl;
  156.     }
  157.      // 对学生考试成绩进行排名
  158.     void rankStudentsByScore() {
  159.         // 按总分排名
  160.         sort(students.begin(), students.end(), [](const Student& a, const Student& b) {
  161.             return a.getAverageScore() > b.getAverageScore();
  162.         });
  163.          // 输出排名结果
  164.         cout << "Ranking by Total Score:" << endl;
  165.         for (int i = 0; i < students.size(); i++) {
  166.             cout << "Rank " << i + 1 << ": " << students[i].getName() << ", Average Score: " << students[i].getAverageScore() << endl;
  167.         }
  168.          // 按科目排名
  169.         vector<string> subjects = { "Math", "English", "Physics" };
  170.         for (const string& subject : subjects) {
  171.             sort(students.begin(), students.end(), [&subject](const
复制代码
游客,本帖隐藏的内容需要积分高于 9 才可浏览,您当前积分为 0



这段代码完成了成绩管理系统的实现。它包括添加学生、按照系别和班级搜索学生、按照科目搜索成绩、按照系别或班级分析成绩以及按照总分排名学生等功能。您可以根据具体需求进一步定制代码。


扫码关注微信公众号,及时获取最新资源信息!下载附件优惠VIP会员5折;永久VIP免费

1万

主题

1万

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
12858
 楼主| 发表于 2024-1-8 12:26:42 | 显示全部楼层


关注微信公众号,回复”学生成绩管理系统C++语言“,免费查阅源码。
扫码关注微信公众号,及时获取最新资源信息!下载附件优惠VIP会员5折;永久VIP免费
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

免责声明:
1、本站提供的所有资源仅供参考学习使用,版权归原著所有,禁止下载本站资源参与商业和非法行为,请在24小时之内自行删除!
2、本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,请勿任何商业目的与商业用途。
3、若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
4、论坛的所有内容都不保证其准确性,完整性,有效性,由于源码具有复制性,一经售出,概不退换。阅读本站内容因误导等因素而造成的损失本站不承担连带责任。
5、用户使用本网站必须遵守适用的法律法规,对于用户违法使用本站非法运营而引起的一切责任,由用户自行承担
6、本站所有资源来自互联网转载,版权归原著所有,用户访问和使用本站的条件是必须接受本站“免责声明”,如果不遵守,请勿访问或使用本网站
7、本站使用者因为违反本声明的规定而触犯中华人民共和国法律的,一切后果自己负责,本站不承担任何责任。
8、凡以任何方式登陆本网站或直接、间接使用本网站资料者,视为自愿接受本网站声明的约束。
9、本站以《2013 中华人民共和国计算机软件保护条例》第二章 “软件著作权” 第十七条为原则:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。若有学员需要商用本站资源,请务必联系版权方购买正版授权!
10、本网站如无意中侵犯了某个企业或个人的知识产权,请来信【站长信箱312337667@qq.com】告之,本站将立即删除。
郑重声明:
本站所有资源仅供用户本地电脑学习源代码的内含设计思想和原理,禁止任何其他用途!
本站所有资源、教程来自互联网转载,仅供学习交流,不得商业运营资源,不确保资源完整性,图片和资源仅供参考,不提供任何技术服务。
本站资源仅供本地编辑研究学习参考,禁止未经资源商正版授权参与任何商业行为,违法行为!如需商业请购买各资源商正版授权
本站仅收集资源,提供用户自学研究使用,本站不存在私自接受协助用户架设游戏或资源,非法运营资源行为。
 
在线客服
点击这里给我发消息 点击这里给我发消息 点击这里给我发消息
售前咨询热线
312337667

微信扫一扫,私享最新原创实用干货

QQ|免责声明|小黑屋|依星资源网 ( 鲁ICP备2021043233号-3 )|网站地图

GMT+8, 2024-12-22 01:16

Powered by Net188.com X3.4

邮箱:312337667@qq.com 客服QQ:312337667(工作时间:9:00~21:00)

快速回复 返回顶部 返回列表