【PAT甲级真题】- Talent and Virtue (25)

题目来源

Talent and Virtue (25)

题目描述

About 900 years ago, a Chinese philosopher Sima Guang wrote a history

book in which he talked about people's talent and virtue. According to his theory, a man being outstanding in both talent and virtue must be a "sage(圣人)"; being less excellent but with one's virtue outweighs talent can be called a "nobleman(君子)"; being good in neither is a "fool man(愚人)"; yet a fool man is better than a "small man(小人)" who prefers talent than virtue. Now given the grades of talent and virtue of a group of people, you are supposed to rank them according to Sima Guang's theory.

输入描述:

Each input file contains one test case. Each case first gives 3 positive integers in a line: N (<=105), the total number of people to be ranked; L (>=60), the lower bound of the qualified grades -- that is, only the ones whose grades of talent and virtue are both not below this line will be ranked; and H (<100), the higher line of qualification -- that is, those with both grades not below this line are considered as the "sages", and will be ranked in non-increasing order according to their total grades. Those with talent grades below H but virtue grades not are cosidered as the "noblemen", and are also ranked in non-increasing order according to their total grades, but they are listed after the "sages". Those with both grades below H, but with virtue not lower than talent are considered as the "fool men". They are ranked in the same way but after the "noblemen". The rest of people whose grades both pass the L line are ranked after the "fool men".

Then N lines follow, each gives the information of a person in the format:

ID_Number Virtue_Grade Talent_Grade

where ID_Number is an 8-digit number, and both grades are integers in [0, 100]. All the numbers are separated by a space.

输出描述:

The first line of output must give M (<=N), the total number of people that are actually ranked. Then M lines follow, each gives the

information of a person in the same format as the input, according to the ranking rules. If there is a tie of the total grade, they must be

ranked with respect to their virtue grades in non-increasing order. If there is still a tie, then output in increasing order of their ID's.

输入例子:

复制代码
14 60 80
10000001 64 90
10000002 90 60
10000011 85 80
10000003 85 80
10000004 80 85
10000005 82 77
10000006 83 76
10000007 90 78
10000008 75 79
10000009 59 90
10000010 88 45
10000012 80 100
10000013 90 99
10000014 66 60

输出例子:

复制代码
12
10000013 90 99
10000012 80 100
10000003 85 80
10000011 85 80
10000004 80 85
10000007 90 78
10000006 83 76
10000005 82 77
10000002 90 60
10000014 66 60
10000008 75 79
10000001 64 90

思路简介

题目看懂了其实就是重载个排序函数而已

题目要求分四个类型来排序就开四个数组就行了

遇到的问题

  1. 忘记输出参与排名的总人数wa了一次

代码

cpp 复制代码
/**
 * https://www.nowcoder.com/pat/5/problem/4029
 * 排序
 */
#include<bits/stdc++.h>
using namespace std;

struct Person{
    int id,talent,virtue;
    
    Person():id(0),talent(0),virtue(0){}
    Person(int id,int talent,int virtue):id(id),talent(talent),virtue(virtue){};

    bool operator< (Person& a){//this<a
        if(this->talent+this->virtue==a.talent+a.virtue){
            if(this->virtue==a.virtue){
                return this->id<a.id;
            }
            return this->virtue>a.virtue;
        }
        return this->talent+this->virtue>a.talent+a.virtue;
    }


};

ostream& operator<<(ostream& out,Person a){
    out<<a.id<<' '<<a.virtue<<' '<<a.talent<<'\n';
    return out;
}

void solve(){
    int n,l,h;
    cin>>n>>l>>h;
    vector<Person>sages,nobleman,foolman,smallman;
    for(int i=0;i<n;++i){
        int id,t,v;
        cin>>id>>v>>t;
        if(t<l||v<l)continue;
        if(t>=h&&v>=h)sages.emplace_back(id,t,v);
        else if(v>=h)nobleman.emplace_back(id,t,v);
        else if(v>=t)foolman.emplace_back(id,t,v);
        else smallman.emplace_back(id,t,v);
    }

    sort(sages.begin(),sages.end());
    sort(nobleman.begin(),nobleman.end());
    sort(foolman.begin(),foolman.end());
    sort(smallman.begin(),smallman.end());

    cout<<sages.size()+nobleman.size()+foolman.size()+smallman.size()<<'\n';

    int len=sages.size();
    for(int i=0;i<len;++i)cout<<sages[i];
    
    len=nobleman.size();
    for(int i=0;i<len;++i)cout<<nobleman[i];

    len=foolman.size();
    for(int i=0;i<len;++i)cout<<foolman[i];

    len=smallman.size();
    for(int i=0;i<len;++i)cout<<smallman[i];
}

int main(){
    ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    //fstream in("in.txt",ios::in);cin.rdbuf(in.rdbuf());
    int T=1;
    //cin>>T;
    while(T--){
        solve();
    }
    return 0;
}
相关推荐
CoderCodingNo3 分钟前
【信奥业余科普】C++ 的奇妙之旅 | 12:程序的交互与加工——数据的输入与算术运算
开发语言·c++
yx868xy10 分钟前
Cuda加速直线拟合
c++·cuda
Robot_Nav11 分钟前
Shape-Aware MPPI(SA MPPI)算法:基于RC-ESDF的任意形状机器人实时轨迹优化
算法·机器人·sa-mppi
蜗牛在听雨35 分钟前
基于 C++ 的 UG/NX 二次开发环境配置
c++·二次开发·ug
gumichef44 分钟前
算法的时间复杂度和空间复杂度
数据结构
SimpleLearingAI1 小时前
C++虚函数详解
开发语言·c++
小O的算法实验室1 小时前
2026年ESWA,自适应基于排序的协同进化学习粒子群算法+边缘计算服务器部署,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
小柯博客1 小时前
STM32MP2安全启动技术深度解析
c语言·c++·stm32·嵌入式硬件·安全·开源·github
cpp_25011 小时前
P1832 A+B Problem(再升级)
数据结构·c++·算法·动态规划·题解·洛谷·背包dp
꧁细听勿语情꧂2 小时前
合并两个有序表、判断链表的回文结构、相交链表、环的链表一和二
c语言·开发语言·数据结构·算法