蓝桥杯备赛:Day1-奖学金

1. 题目:[P1093 NOIP2007 普及组] 奖学金

📝 我的代码 (AC Version)
c++ 复制代码
#include<bits/stdc++.h>
using namespace std;

// 1. 定义结构体存储多维度数据
struct student {
    int Chinese;
    int Math;
    int English;
    int Sum;
    int Number;
} a[305]; // 数组开大 5 个空间防止越界

// 2. 核心排序逻辑:自定义比较函数
bool comp(student xx, student yy) {
    // 优先级 1:总分大的在前 (降序)
    if (xx.Sum != yy.Sum)
        return xx.Sum > yy.Sum;
    // 优先级 2:总分一样,语文大的在前 (降序)
    if (xx.Chinese != yy.Chinese)
        return xx.Chinese > yy.Chinese;
    // 优先级 3:都一样,编号小的在前 (升序)
    return xx.Number < yy.Number;
}

int n;

int main() {
    // 优化输入输出效率
    ios::sync_with_stdio(0), cin.tie(0);
    
    if (!(cin >> n)) return 0;

    for (int i = 1; i <= n; i++) {
        cin >> a[i].Chinese >> a[i].Math >> a[i].English;
        a[i].Sum = a[i].Chinese + a[i].Math + a[i].English;
        a[i].Number = i;
    }
    
    // 3. 调用 STL sort 函数 (左闭右开区间)
    sort(a + 1, a + n + 1, comp);
    
    // 4. 严格按题目要求格式输出
    for (int i = 1; i <= 5; i++) {
        cout << a[i].Number << " " << a[i].Sum << endl;
    }
    
    return 0;
}

🎯 核心考点说明

1. 结构体 (struct) 的应用
  • 适用场景:当一个物体(如学生)有多个属性(姓名、成绩、学号)且这些属性需要"绑定"在一起排序时,必须使用结构体。
  • 定义技巧struct 类型名 { 成员列表 } 变量名[大小];
2. STL sort 与自定义 comp 函数
  • sort 语法sort(起始地址, 结束地址, 比较规则);
  • 左闭右开 :排 a[1]a[n],参数是 a + 1a + n + 1
  • 比较逻辑comp 返回 true 代表第一个参数应该排在前面。
3. 多级排序逻辑
  • 采用 if-elseif 过滤法:先判断最重要的条件,如果不相等直接返回;如果相等,再进入下一级条件的判断。

⚠️ 注意事项

  • 头文件 :使用 #include <bits/stdc++.h> 可以省去记各种库的麻烦。
  • IO 优化ios::sync_with_stdio(0), cin.tie(0); 是蓝桥杯大题必加项,防止在大规模数据下超时。
  • 数组大小 :题目给出 N ≤ 300 N \le 300 N≤300,数组开 305 是一种防御性编程习惯,避免 i+1 等操作导致越界。

❌ 我犯的错误 (避坑指南)

  1. 语法细节错误
    • for 循环括号内误用逗号 ,,应使用分号 ;
    • cout 流向写反(误写为 >>),正确应为 <<
  2. 输出格式错误 (WA 的主要原因)
    • 多余空格 :在两个输出变量之间加了多个空格。判题机对空格极其敏感,必须严格按照题目要求的"一个空格"输出。
    • 特殊字符:从网页复制粘贴可能带有不可见的特殊编码字符,导致判题失败。建议引号内的内容手动输入。
  3. 逻辑遗漏
    • 忘记了题目要求只输出"前 5 名",最初代码缺少了输出限制循环。
相关推荐
汉克老师2 小时前
GESP2025年6月认证C++三级( 第三部分编程题(1、奇偶校验)
c++·算法·gesp三级·gesp3级·按位操作
CoderCodingNo2 小时前
【GESP】C++八级考试大纲知识点梳理 (8) 算法优化技巧
开发语言·c++
十年编程老舅3 小时前
窥探内核心脏:深入解析 proc 虚拟文件系统
linux·服务器·数据库·c++·linux内核·文件系统·读写锁
xiaoye-duck3 小时前
【C++:哈希表】从哈希冲突到负载因子:深入探索开放定址与链地址法的核心机密
数据结构·c++·散列表
小辉同志3 小时前
739. 每日温度
c++·算法·leetcode
爱编码的小八嘎4 小时前
C语言完美演绎6-14
c语言
羊小猪~~4 小时前
Redis学习笔记(数据类型、持久化、事件、管道、发布订阅等)
开发语言·数据库·c++·redis·后端·学习·缓存
小菜鸡桃蛋狗5 小时前
C++——模板
c++
程序喵大人5 小时前
C++依赖关系分析:5个工具理清模块关系
开发语言·c++