【GDOI2022PJD1T1 邹忌讽齐王纳谏】题解
D1T1 邹忌讽齐王纳谏
题目
齐国人邹忌对齐国国君齐威王说,大王身边的人会因为私情、利益等原因而对大王阿谀奉承,所以不能光听好话,只有广泛接受群众的批评意见,才不会被蒙蔽双眼,齐国才能强盛。齐威王接受了这个意见,于是昭告全国:
- 如果有臣民当面对齐威王提出建议,则获得价值为 A 的奖励;
- 如果有臣民以书信的方式对齐威王提出建议,则获得价值为 B 的奖励;
- 如果有臣民在街市中议论齐威王,意见流传到宫廷,则获得价值为 C 的奖励。
你通过史书整理出了某一年的建议记录,按时间顺序罗列,共有 n 条,每条记录形如”name way”,其中 name 是由小写英文字母组成的字符串(由于博物馆的计算机太古老了,只支持英文,所以你也只能用英文做记录),表示提建议者的名字;way 是一个为 1、2 或 3 的数字,表示提建议的方式。
你发现记录中有些人提出了多次建议,从而获得多次奖励,因此你很好奇这些人之中获得奖励总和最多的是谁,他总共获得了多少奖励。
如果获得最多奖励的不止一个人,请输出最早获得最多奖励的人。
思路
语法题。
按照题意所说模拟,把每个人的名字转成数字然后放到一个桶里面(或者直接试string+map也行)。
桶记录的是每个人的贡献,动态维护最大值即可。
注意考虑全0情况。(不过数据好像没卡)
Code
#include<bits/stdc++.h>
using namespace std;
//#define int long long
inline int read(){int f=1,x=0;char ch=getchar();while(ch<'0'||
ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9'){
x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}return x*f;}
//#define N
//#define M
//#define mo
int n, m, i, j, k, T, x[5], mx=-1, mi;
string s, c;
map<string, int>mp;
signed main()
{
cin>>n>>x[1]>>x[2]>>x[3];
for(i=1; i<=n; ++i)
{
cin>>s>>j;
mp[s]+=x[j];
if(mp[s]>mx) mx=mp[s], c=s;
}
cout<<c<<" "<<mx;
return 0;
}
总结
这是一道挺语法的题目。
数据没有卡全0的情况,但有时在做这种题的时候需要考虑。
对于最大值的初始值,可以默认赋为-inf,也可以去考虑最大值最小为多少。
本文来自博客园,作者:zhangtingxi,转载请注明原文链接:https://www.cnblogs.com/zhangtingxi/p/16179574.html