每日c/c++题 备战蓝桥杯(P1093 [NOIP 2007 普及组] 奖学金)

洛谷P1093 [NOIP 2007 普及组] 奖学金 详解题解

题目背景与要求

题目链接:P1093 奖学金
核心任务:根据学生三科总分评选前5名奖学金获得者,需按特定规则排序输出。

排序规则(按优先级从高到低):

  1. 总分降序:总分高者排名靠前
  2. 语文降序:总分相同时,语文成绩高者优先
  3. 原始序号升序:前两项均相同时,按输入顺序排列

算法设计解析

核心思想:多级条件排序

本题本质是多关键字排序问题的典型实现,需特别注意以下关键点:

关键维度处理要求实现难点
主排序总分降序正确处理降序比较逻辑
次排序语文降序避免与总分排序逻辑冲突
终极条件原始输入顺序需保持输入顺序的稳定性

数据结构选择

采用结构体封装学生信息,实现数据与逻辑的解耦:

struct Student {int id;      // 原始序号(从1开始)int chinese; // 语文成绩int math;    // 数学成绩int english; // 英语成绩int total;   // 三科总分(可动态计算)
};

自定义比较函数

通过三级条件判断实现精准排序:

bool compare(const Student& a, const Student& b) {if (a.total != b.total) {return a.total > b.total; // 总分降序}if (a.chinese != b.chinese) {return a.chinese > b.chinese; // 语文降序}return a.id < b.id; // 原始序号升序
}

代码实现与优化

完整代码

#include <algorithm>
#include <iostream>
using namespace std;struct Student {int id;int chinese;int math;int english;int total;
};Student students[305];bool compare(const Student& a, const Student& b) {if (a.total != b.total) return a.total > b.total;if (a.chinese != b.chinese) return a.chinese > b.chinese;return a.id < b.id;
}int main() {ios::sync_with_stdio(false);cin.tie(nullptr);int n;cin >> n;for (int i = 1; i <= n; ++i) {cin >> students[i].chinese >> students[i].math >> students[i].english;students[i].id = i;students[i].total = students[i].chinese + students[i].math + students[i].english;}stable_sort(students + 1, students + n + 1, compare);const int output_count = min(5, n);for (int i = 1; i <= output_count; ++i) {cout << students[i].id << " " << students[i].total << "\n";}return 0;
}

关键实现细节

  1. 稳定排序策略
    使用stable_sort而非普通sort,确保当总分和语文成绩均相同时,保持原始输入顺序。这是实现第三排序条件的核心保障。

  2. 输入输出优化
    通过以下操作将IO效率提升3-5倍:

    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    
  3. 动态总分计算
    在输入时实时计算总分,避免后续重复计算:

    students[i].total = chinese + math + english;
    

算法复杂度分析

指标复杂度说明
时间复杂度O(n log n)主导因素为稳定排序操作
空间复杂度O(n)存储学生信息的结构体数组
额外空间O(1)原地排序算法

测试样例详解

输入示例

6
90 67 80
87 66 91
78 89 91
88 99 77
67 89 64
78 89 98

输出解析

6 265  // 原始序号6,总分98+89+78=265
4 264  // 原始序号4,总分99+88+77=264
3 258  // 原始序号3,总分91+89+78=258
2 244  // 原始序号2,总分91+66+87=244
1 237  // 原始序号1,总分80+67+90=237

关键观察

  • 学生6和学生4总分仅差1分,但语文成绩相同(78 vs 88?此处需验证输入数据)
  • 当总分和语文成绩均相同时(如假设存在多个学生),原始序号将决定最终排名

常见错误规避

  1. 排序稳定性缺失
    ❌ 错误使用sort代替stable_sort
    ✅ 必须使用稳定排序保持原始顺序

  2. 比较逻辑错误
    ❌ 语文成绩误用升序比较
    ✅ 需明确降序使用>运算符

  3. 序号处理不当
    ❌ 从0开始编号导致输出错误
    ✅ 输入时保持1-based编号

  4. 输出范围错误
    ❌ 固定输出5行导致n<5时越界
    ✅ 使用min(5, n)动态控制输出量

总结与扩展

本题通过结构化数据封装和自定义比较函数,完整演示了多条件排序的实现范式。其核心思想可扩展至:

  • 电商平台的商品综合排序(价格+销量+评价)
  • 学生成绩多维度排名(总分+单科+考勤)
  • 数据库的多字段排序查询

掌握稳定排序算法的应用场景,对于处理需要保持相等元素原始顺序的排序问题具有重要实践意义。在实际工程中,可根据具体需求选择stable_sort或普通sort,并合理设计比较函数的多级条件判断逻辑。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/81127.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

openEuler 22.03 安装 Nginx,支持离线安装

目录 一、环境检查1.1 必要环境检查1.2 在线安装&#xff08;有网络&#xff09;1.3 离线安装&#xff08;无网络&#xff09; 二、下载Nginx2.1 在线下载2.2 离线下载 三、安装Nginx四、开机自启服务五、开放防火墙端口六、常用命令 一、环境检查 1.1 必要环境检查 # 查看 g…

基于深度学习的图像压缩技术(二)

接上篇&#xff1a;基于深度学习的图像压缩技术&#xff08;一&#xff09;-CSDN博客 3 基于生成对抗神经网络的图像压缩技术 生成对抗网络是一种先进的无监督学习算法&#xff0c;由Goodfellow等人在2014 年首次提出&#xff0c;其核心思想源于博弈论。 生成对抗网络在图像压…

TCP和UDP的数据传输+区别

目录 一、数据传输过程 1.1 TCP字节流服务图 1.2 UDP数据报服务图 二、tcp与udp的区别 1.连接方式 2.可靠性 3.传输效率 4.有序性 5.流量控制和拥塞控制 6.应用场景 7.首部长度 三、tcp与udp能不能使用同一个端口号&#xff1f; 四、同一个协议&#xf…

基于ssm的校园旧书交易交换平台(源码+文档)

项目简介 校园旧书交易交换平台的主要使用者分为&#xff1a; 前台功能&#xff1a;用户进入系统可以对首页、书籍信息、校园公告、个人中心、后台管理等功能进行操作&#xff1b; 后台主要是管理员&#xff0c;管理员功能包括主页、个人中心、学生管理、发布人管理、书籍分类…

虚假安全补丁攻击WooCommerce管理员以劫持网站

一场大规模钓鱼攻击正针对WooCommerce用户&#xff0c;通过伪造安全警报诱使他们下载所谓的"关键补丁"&#xff0c;实则为植入WordPress后门的恶意程序。 恶意插件植入 根据Patchstack研究人员发现&#xff0c;上当受骗的用户在下载更新时&#xff0c;实际上安装的…

《冰雪传奇点卡版》:第二大陆介绍!

一、第二大陆&#xff1a;高阶资源与实力验证的核心战场 1. 准入条件与地图分布 进入门槛&#xff1a; 基础要求&#xff1a;角色需达到四转&#xff08;需消耗50万元宝完成转生任务&#xff09;&#xff0c;部分地图需额外满足神魔点数&#xff08;如黑暗之森需神魔全2&#…

信创系统图形界面开发指南:技术选择与实践详解

信创系统图形界面开发指南&#xff1a;技术选择与实践详解 &#x1f9d1; 博主简介&#xff1a;CSDN博客专家、CSDN平台优质创作者&#xff0c;高级开发工程师&#xff0c;数学专业&#xff0c;10年以上C/C, C#, Java等多种编程语言开发经验&#xff0c;拥有高级工程师证书&…

【人脸去遮挡前沿】三阶段级联引导学习如何突破真实场景遮挡难题?

一、现实痛点:当人脸被遮挡,AI “认脸” 有多难? 你是否遇到过这样的场景? 中考体育测试:2025 年天津泰达街中考考场要求考生 “脸部无遮挡” 才能通过人脸识别入场,戴口罩、帽子的学生需现场调整发型。智能门锁:奇景光电在 CES 2025 推出的 WiseEye 掌静脉模块,通过掌…

c++线程的创建

c 11 线程编程实战 目录 c 11 线程编程实战1&#xff0c;线程的创建1.1 传入无参函数1.2 传入有参函数1.3 传入类内部函数1.4 lambda表达式 1&#xff0c;线程的创建 1.1 传入无参函数 //传入函数&#xff0c;创建线程 void ThreadMain() {//获取线程IDstd::thread::id thi…

人工智能数学基础(六):数理统计

数理统计是人工智能中数据处理和分析的核心工具&#xff0c;它通过收集、分析数据来推断总体特征和规律。本文将系统介绍数理统计的基本概念和方法&#xff0c;并结合 Python 实例&#xff0c;帮助读者更好地理解和应用这些知识。资源绑定附上完整资源供读者参考学习&#xff0…

解决STM32待机模式无法下载程序问题的深度探讨

在现代嵌入式系统开发中&#xff0c;STM32系列微控制器因其高性能、低功耗和丰富的外设资源而广受欢迎。然而&#xff0c;开发者在使用STM32时可能会遇到一个问题&#xff1a;当微控制器进入待机模式后&#xff0c;无法通过调试接口&#xff08;如SWD或JTAG&#xff09;下载程序…

C#扩展方法与Lambda表达式基本用法

C# 扩展方法与 Lambda 表达式详解 一、扩展方法详解 1. 基本概念 ​​扩展方法​​允许为现有类型"添加"方法&#xff0c;而无需修改原始类型或创建派生类型。 ​​定义条件​​&#xff1a; 必须在静态类中定义方法本身必须是静态的第一个参数使用this修饰符指…

C#规避内存泄漏的编码方法

C#规避内存泄漏的编码方法 内存泄漏是C#开发中常见的问题&#xff0c;尽管.NET有垃圾回收机制(GC)&#xff0c;但不当的编码实践仍可能导致内存无法被及时回收。以下是系统性的规避内存泄漏的方法&#xff1a; 一、理解内存泄漏的常见原因 ​​未释放的事件订阅​​​​静态…

React 后台管理系统

这是一个基于 React TypeScript Ant Design 开发的向明天系统前端项目。 git仓库地址 技术栈 React 19TypeScriptAnt Design 5.xRedux ToolkitReact RouterAxiosLess 环境要求 Node.js (推荐使用最新LTS版本)npm 或 yarn 安装步骤 克隆项目到本地 git clone [https://…

第九节:文件操作

理论知识 文件的基本概念&#xff1a;文件是存储数据的基本单位&#xff0c;在 Linux 系统中&#xff0c;一切皆文件。文件可以是文本文件、二进制文件、设备文件等。文件的创建&#xff1a;使用 touch 命令可以创建一个新的空文件。如果文件已经存在&#xff0c;则更新文件的…

2025-03 机器人等级考试四级理论真题 4级

1 2025年蛇年春晚&#xff0c;节目《秧BOT》机器人舞蹈表演节目点燃了全国观众的热情&#xff0c;请问参加节目表演的机器人是由哪家公司研发&#xff1f;&#xff08; &#xff09; A.大疆 B.华为 C.优必选 D.宇树科技 【参考答…

k8s平台:手动部署Grafana

以下是一个可用于生产环境的 Kubernetes 部署 Grafana 的 YAML 文件。该配置包括 Deployment、Service、ConfigMap 和 PersistentVolumeClaim&#xff0c;确保 Grafana 的高可用性和数据持久化。 Grafana 生产部署 YAML 文件 ☆实操示例 cat grafana-deployment.yaml --- # …

农产品园区展示系统——仙盟创梦IDE开发

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>农业大数据平台</title><style>* {margi…

每日Bug:(2)共享内存

对于整个系统而言&#xff0c;主存与CPU的资源都是有限的&#xff0c;随着打开进程数量的增加&#xff0c;若是将所有进程运行所需的代码/数据/栈/共享库都存放在主存中&#xff0c;那么开启一部分进程就可以将主存占用完。 虚拟内存就是解决以上问题的方法&#xff0c;使用虚…

C语言Makefile编写与使用指南

Makefile 详细指南&#xff1a;编写与使用 Makefile 是 C/C 项目中常用的自动化构建工具&#xff0c;它定义了项目的编译规则和依赖关系。下面我将详细介绍 Makefile 的编写和使用方法。 一、Makefile 基础 1. 基本结构 一个典型的 Makefile 包含以下部分&#xff1a; mak…