7-43 电话聊天狂人 (25 分)
给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人。
输入格式:
输入首先给出正整数N(≤105),为通话记录条数。随后N行,每行给出一条通话记录。简单起见,这里只列出拨出方和接收方的11位数字构成的手机号码,其中以空格分隔。
输出格式:
在一行中给出聊天狂人的手机号码及其通话次数,其间以空格分隔。如果这样的人不唯一,则输出狂人中最小的号码及其通话次数,并且附加给出并列狂人的人数。
输入样例:
4
13005711862 13588625832
13505711862 13088625832
13588625832 18087925832
15005713862 13588625832
输出样例:
13588625832 3
解析:这道题来来回回提交了七八次,前几次提交得12分,后来改改居然变成了零分,哭死。后来总算改出来了 。这道题光看输入格式是两个号码两两对应,我们就应该想到也是用map来写(类似于单身狗那题),需要掌握的是map数值的插入方式以及访问方式。正确代码如下:
#include<bits/stdc++.h>
using namespace std;
map<long long,int>p;
int main()
{
int n,i,max=0,num=0;
long long s,t,g,h;
scanf(&#