为了用事实说明挖掘机技术到底哪家强,PAT组织了一场挖掘机技能大赛。现请你根据比赛结果统计出技术最强的那个学校。
输入描述:
输入在第1行给出不超过105的正整数N,即参赛人数。随后N行,每行给出一位参赛者的信息和成绩,包括其所代表的学校的编号、及其比赛成绩(百分制),中间以空格分隔。
输出描述:
在一行中给出总得分最高的学校的编号、及其总分,中间以空格分隔。题目保证答案唯一,没有并列。
示例1
输入
6 3 65 2 80 1 100 2 70 3 40 3 0
输出
2 150
#include<bits/stdc++.h>
using namespace std;
const int N=100010;
map<int,int>nd;
int val[N];
int main(){
memset(val,0,sizeof(val));
int n;
scanf("%d",&n);
int id,score;
for(int i=0;i<n;i++){
scanf("%d%d",&id,&score);
nd[id]+=score;
}
//map<int,int>::reverse_iterator it=nd.rbegin();
map<int,int>::iterator it=nd.begin();
int maxn=0,idd;
for(;it!=nd.end();it++){
if(it->second>maxn){
idd=it->first;
maxn=it->second;
}
}
cout<<idd<<" "<<maxn<<endl;
return 0;
}
/*
6
3 65
2 80
1 100
2 70
3 40
3 0
*/