ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

【GDOI2022PJD1T1】邹忌讽齐王纳谏

2022-04-22 17:02:12  阅读:156  来源: 互联网

标签:ch 邹忌 int GDOI2022PJD1T1 获得 奖励 mp 齐威王 讽齐王


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,也可以去考虑最大值最小为多少。

标签:ch,邹忌,int,GDOI2022PJD1T1,获得,奖励,mp,齐威王,讽齐王
来源: https://www.cnblogs.com/zhangtingxi/p/16179574.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有