c++ 成绩统计

Q:

有一个二维表格数据,它的值全部是整数,其中存储了若干个选手参与5分钟汉字输入比赛的成绩。数据中每一行是一条记录,每条记录包含两个整数,第1个整数为选手编号,它应该是一个4位整数;第2个整数是汉字输入比赛成绩,应该是一个小于等于1000的非负整数。数据中每个选手最多可能有2条记录。编写程序删除数据中的无效记录和每个选手的多余记录,每个选手只保留有效成绩中成绩最高的一条记录,然后返回成绩排名第2的选手编号(当成绩相同时编号小的选手在前),如果不足2个选手,则返回第1的选手编号。注意: 测试数据保证按照 要求删除数据后,至少有一条记录。

|------|--------------------------------------------------------|
| 相关说明 ||
| 输入条件 | 1. 输入的二维表格数据中的数据一定全部是整数, 1. 二维表格数据中每一行一定是两个整数 |
| 输出要求 | 1. 输出选手的编号一定是一个4位整数 |
| 其它要求 | 将代码写入函数func4 |

测试用例:

|---------------------------------------------------|------|
| 输入 | 返回 |
| [[1,2] ,[1022,888]] | 1022 |
| [[1,2],[1022,888],[1011,888]] | 1022 |
| [[1,2],[1011,888],[1011,800]] | 1011 |
| [[1,2],[1011,888],[1011,800],[1025,45]] | 1025 |

cpp 复制代码
#include <bits/stdc++.h>
#include <cstring>
using namespace std;

//=================================================
// 说明:编程题4
// 参数说明: vector<vector<int> >& records: 二维整型向量,每一行表示一条记录
// 返回值: 返回成绩排名第2的选手编号(当成绩相同时编号小的选手在前)
//=================================================
int cmp(pair<int,int> p1,pair<int,int> p2){
    if (p1.second == p2.second)return p1.first<=p2.first;
    return p1.second>=p2.second;

}
int func4(vector<vector<int> >& records)
{
    unordered_map<int,int> valid_records;

    for (auto r : records){
        int id = r[0];
        int score = r[1];
        if (score>=0 && score<=1000){
            if (valid_records.find(id)!= valid_records.end())valid_records[id] = max(score,valid_records[id]);
            else valid_records[id] = score;
        }
    }
    vector<pair<int,int>> result;
    for (auto vr : valid_records)result.push_back(make_pair(vr.first,vr.second));

    sort(result.begin(),result.end(),cmp);

    if (result.size()>1)cout<<result[1].first;
    else cout<<result[1].first;


}
int main(){
    vector<vector<int> > records;

    records.push_back({1,2});
    records.push_back({1011,800});
    records.push_back({1015,888});
    records.push_back({1011,888});

    records.push_back({1025,45});
    func4(records);

}
相关推荐
沐怡旸18 小时前
【穿越Effective C++】条款13:以对象管理资源——RAII原则的基石
c++·面试
一个不知名程序员www18 小时前
算法学习入门---二分查找(C++)
c++·算法
2301_8079973819 小时前
代码随想录-day26
数据结构·c++·算法·leetcode
闭着眼睛学算法19 小时前
【双机位A卷】华为OD笔试之【排序】双机位A-银行插队【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·javascript·c++·python·算法·华为od
小欣加油19 小时前
leetcode 3318 计算子数组的x-sum I
c++·算法·leetcode·职场和发展
j_xxx404_20 小时前
C++ STL:list|了解list|相关接口|相关操作
开发语言·c++
kyle~20 小时前
机器视觉---Intel RealSense SDK 2.0 开发流程
运维·c++·windows·深度相机·intel realsense
脏脏a20 小时前
类与对象(上):面向过程到面向对象的跨越,类的定义、封装与 this 指针等核心概念深度剖析
开发语言·c++
AI柠檬20 小时前
C语言基于MPI并行计算矩阵的乘法
c语言·c++·算法
小无名呀20 小时前
socket_udp
linux·网络·c++·网络协议·计算机网络·udp