c语言学生要求填写4个不同的专业编码,第一次志愿学校要求先按专业编码录取,如果专业人数招满后,再按学生成绩依次录取。第二次录取学校在成绩减5分的基础上,与第一次志愿的要求一样,这个有关代码举例

时间: 2024-02-05 20:03:57 浏览: 30
假设有如下的专业编码和对应的人数限制: | 专业编码 | 人数限制 | | -------- | -------- | | 1001 | 50 | | 1002 | 30 | | 1003 | 20 | | 1004 | 40 | 那么,可以先定义一个结构体 `Major` 来存储每个专业的信息: ```c typedef struct { int code; // 专业编码 int limit; // 人数限制 int count; // 已录取人数 } Major; ``` 然后,定义一个数组 `majors` 来存储所有的专业信息: ```c Major majors[] = { {1001, 50, 0}, {1002, 30, 0}, {1003, 20, 0}, {1004, 40, 0}, }; ``` 接下来,可以用一个循环来让学生填写志愿: ```c int choices[4]; // 保存 4 个专业编码 for (int i = 0; i < 4; i++) { printf("请输入第 %d 个专业编码:", i+1); scanf("%d", &choices[i]); } ``` 然后,按照第一次录取的要求,先按照专业编码录取,如果专业人数招满后,再按照学生成绩依次录取。假设有一个学生结构体 `Student`,其中包含学生的姓名和成绩: ```c typedef struct { char name[20]; int score; } Student; ``` 那么,可以定义一个数组 `students` 来存储所有的学生信息: ```c Student students[] = { {"张三", 80}, {"李四", 90}, {"王五", 85}, {"赵六", 75}, {"钱七", 95}, {"孙八", 70}, {"周九", 87}, {"吴十", 92}, {"郑一", 78}, {"冯二", 89}, }; int n = sizeof(students) / sizeof(Student); // 学生人数 ``` 接下来,可以按照第一次录取的要求,先按照专业编码录取,如果专业人数招满后,再按照学生成绩依次录取: ```c for (int i = 0; i < 4; i++) { int code = choices[i]; // 当前志愿的专业编码 for (int j = 0; j < n; j++) { if (students[j].score < 60) { // 不及格的学生跳过 continue; } for (int k = 0; k < 4; k++) { if (majors[k].code == code) { if (majors[k].count < majors[k].limit) { // 专业人数未满,直接录取 printf("%s 被录取到专业 %d\n", students[j].name, code); majors[k].count++; break; // 跳出循环,继续录取下一个志愿 } else { // 专业人数已满,按照成绩顺序录取 for (int m = j; m < n; m++) { if (students[m].score < 60) { // 不及格的学生跳过 continue; } if (majors[k].count < majors[k].limit) { // 仍未满员,录取该学生 printf("%s 被录取到专业 %d(按成绩顺序录取)\n", students[m].name, code); majors[k].count++; break; // 跳出循环,继续录取下一个志愿 } } break; // 跳出循环,继续录取下一个志愿 } } } } } ``` 至此,第一次录取结束。接下来,按照第二次录取的要求,在成绩减 5 分的基础上,按照第一次录取的要求录取: ```c for (int i = 0; i < 4; i++) { int code = choices[i]; // 当前志愿的专业编码 for (int j = 0; j < n; j++) { if (students[j].score - 5 < 60) { // 不及格的学生跳过 continue; } for (int k = 0; k < 4; k++) { if (majors[k].code == code) { if (majors[k].count < majors[k].limit) { // 专业人数未满,直接录取 printf("%s 被录取到专业 %d\n", students[j].name, code); majors[k].count++; break; // 跳出循环,继续录取下一个志愿 } else { // 专业人数已满,按照成绩顺序录取 for (int m = j; m < n; m++) { if (students[m].score - 5 < 60) { // 不及格的学生跳过 continue; } if (majors[k].count < majors[k].limit) { // 仍未满员,录取该学生 printf("%s 被录取到专业 %d(按成绩顺序录取)\n", students[m].name, code); majors[k].count++; break; // 跳出循环,继续录取下一个志愿 } } break; // 跳出循环,继续录取下一个志愿 } } } } } ``` 完整代码如下:

相关推荐

最新推荐

recommend-type

小学生测验C语言课程设计报告

1.通过本课程设计,培养上机动手能力,使学生巩固《C语言程序设计》课程学习的内容,掌握工程软件设计的基本方法,强化上机动手能力,闯过编程关; 2.为后续各门计算机课程的学习打下坚实基础; 3.理解程序设计的思路...
recommend-type

C语言实现输入一个字符串后打印出该字符串中字符的所有排列

主要介绍了C语言实现输入一个字符串后打印出该字符串中字符的所有排列的方法,是数学中非常实用的排列算法,需要的朋友可以参考下
recommend-type

c语言作业——学生成绩统计.docx

整个程序功能 (1)学生基本信息(学号、姓名、…….)录入; (2)学生成绩录入; (3)统计学生成绩分布情况(每个分数段人数);...(6)统计不同生源地学生的平均成绩,按平均成绩排序,并输出结果。
recommend-type

C语言实现简单学生学籍管理系统

主要为大家详细介绍了C语言实现简单学生学籍管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言实现学生选课系统完整版

主要为大家详细介绍了C语言实现学生选课系统的完整版,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

中文翻译Introduction to Linear Algebra, 5th Edition 2.1节

中文翻译Introduction to Linear Algebra, 5th Edition 2.1节 线性代数的核心问题是求解方程组。这些方程都是线性的,即未知数仅与数相乘——我们绝不会 遇见 x 乘以 y。我们的第一个线性方程组较小。接下来你来看看它引申出多远: 两个方程 两个未知数 x − 2y = 1 3x + 2y = 11 (1) 我们一次从一个行开始。第一个方程 x − 2y = 1 得出了 xy 平面的一条直线。由于点 x = 1, y = 0 解 出该方程,因此它在这条直线上。因为 3 − 2 = 1,所以点 x = 3, y = 1 也在这条直线上。若我们选择 x = 101,那我们求出 y = 50。 这条特定直线的斜率是 12,是因为当 x 变化 2 时 y 增加 1。斜率在微积分中很重要,然而这是线 性代数! 图 2.1 将展示第一条直线 x − 2y = 1。此“行图”中的第二条直线来自第二个方程 3x + 2y = 11。你 不能错过两条线的交点 x = 3, y = 1。点 (3, 1) 位于两条线上并且解出两个方程。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

识别MATLAB微分方程求解中的混沌行为:分析非线性方程混沌行为的实用技巧

![matlab求解微分方程](https://img-blog.csdnimg.cn/2021062810300367.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MTQ3OTY3OA==,size_16,color_FFFFFF,t_70) # 1. MATLAB微分方程求解概述 微分方程是描述物理、工程和金融等领域中动态系统的数学模型。MATLAB提供了强大的工具来求解微分方程,包括内置求解器和自定义函数
recommend-type

physon如何做ERP系统

作为一个AI语言模型,我可以给您提供一些基本的建议和思路: 1.明确需求和目标:在开始开发ERP系统之前,需要明确您的业务需求和目标,了解您的业务流程、流程数据、员工角色和权限、财务管理等方面的要求,这样才能更好的设计和开发ERP系统。 2.选择技术框架和开发工具:选择合适的技术框架和开发工具是ERP系统开发的关键。选择一种流行的技术框架和工具可以提高开发效率和质量。 3.设计数据库:ERP系统需要一个功能强大的数据库来存储数据。设计数据库需要考虑数据的完整性、安全性和可扩展性。 4.设计系统架构:系统架构是ERP系统的骨架,需要考虑系统的可扩展性、可维护性和性能。 5.开发和测试:
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。