【GDOI2022PJD1T1 邹忌讽齐王纳谏】题解

D1T1 邹忌讽齐王纳谏

题目

齐国人邹忌对齐国国君齐威王说,大王身边的人会因为私情、利益等原因而对大王阿谀奉承,所以不能光听好话,只有广泛接受群众的批评意见,才不会被蒙蔽双眼,齐国才能强盛。齐威王接受了这个意见,于是昭告全国:

  1. 如果有臣民当面对齐威王提出建议,则获得价值为 A 的奖励;
  2. 如果有臣民以书信的方式对齐威王提出建议,则获得价值为 B 的奖励;
  3. 如果有臣民在街市中议论齐威王,意见流传到宫廷,则获得价值为 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,也可以去考虑最大值最小为多少。

posted @ 2022-04-22 16:53  zhangtingxi  阅读(112)  评论(0编辑  收藏  举报