题目地址

https://pta.patest.cn/pta/test/15/exam/4/question/722

5-14 电话聊天狂人   (25分)

给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人。

输入格式:

输入首先给出正整数NN(\le 10^5≤10​5​​),为通话记录条数。随后NN行,每行给出一条通话记录。简单起见,这里只列出拨出方和接收方的11位数字构成的手机号码,其中以空格分隔。

输出格式:

在一行中给出聊天狂人的手机号码及其通话次数,其间以空格分隔。如果这样的人不唯一,则输出狂人中最小的号码及其通话次数,并且附加给出并列狂人的人数。

输入样例:

4
13005711862 13588625832
13505711862 13088625832
13588625832 18087925832
15005713862 13588625832

输出样例:

13588625832 3

链地址实现
/*
评测结果
时间 结果 得分 题目 编译器 用时(ms) 内存(MB) 用户
2017-07-07 14:54 正在评测 0 5-14 gcc 无 无
测试点结果
测试点 结果 得分/满分 用时(ms) 内存(MB)
测试点1 答案正确 12/12 2 2
测试点2 答案正确 3/3 2 2
测试点3 答案正确 10/10 105 11 电话号码有11位,故用hash表解决
*/
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MAXN 110000
#define ERROR -1
typedef struct UserNode * ptrUser; struct UserHashTable
{
ptrUser Head;
} gHashTable[MAXN]; struct UserNode
{
char phonenumber[20];
int count;
ptrUser next; //冲突的值用链表串起来
}; void InitHashTable()
{
int i;
for (i=0;i<MAXN;i++)
{
gHashTable[i].Head=NULL;
}
} int Hash(char *num) //取后末尾四位,以及正数第三位电话号码做hash值
{
int i=0,result;
result=(num[10]-'0')+(num[9]-'0')*10+(num[8]-'0')*100+(num[7]-'0')*1000+(num[2]-'0')*10000;
return result;
} ptrUser CreateUserNode(char *a)
{
ptrUser P;
P=malloc(sizeof(struct UserNode));
P->count=1;
P->next=NULL;
strcpy(P->phonenumber,a);
} void InsertUserToTable(ptrUser T)
{
int idx;
idx=Hash(T->phonenumber);
T->next=gHashTable[idx].Head;
gHashTable[idx].Head=T;
} ptrUser FindUser(char *num)
{
int idx;
ptrUser T;
idx=Hash(num);
T=gHashTable[idx].Head;
while(T!=NULL)
{
if(strcmp(T->phonenumber,num)==0)
return T;
T=T->next;
}
return NULL;
} void Count()
{
char maxnumber[20];
int i,maxcount=0,samecount=1;
ptrUser P;
for(i=0;i<MAXN;i++)
{
P=gHashTable[i].Head;
while(P!=NULL)
{
if(P->count > maxcount)
{
maxcount=P->count;
strcpy(maxnumber,P->phonenumber);
samecount=1;
}
else
{
if(P->count==maxcount)
samecount++;
if(P->count==maxcount && strcmp(maxnumber,P->phonenumber)>0)
{
strcpy(maxnumber,P->phonenumber);
}
} P=P->next;
} } printf("%s %d",maxnumber,maxcount);
if(samecount>1)
{
printf(" %d",samecount);
} } int main()
{
int i,N,temp;
char a[20],b[20];
ptrUser P;
scanf("%d",&N);
InitHashTable();
for(i=0;i<N;i++)
{
scanf("%s %s",a,b);
P=FindUser(a);
if(P==NULL)
{
P=CreateUserNode(a);
InsertUserToTable(P);
}
else
P->count++; P=FindUser(b);
if(P==NULL)
{
P=CreateUserNode(b);
InsertUserToTable(P);
}
else
P->count++;
}
Count(); }

  

PTA 11-散列1 电话聊天狂人 (25分)的更多相关文章

  1. PTA 5-14 电话聊天狂人 (25分)

    给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数NN(\le 10^5≤10​5​​),为通话记录条数.随后NN行,每行给出一条通话记录.简单起见,这里只列出 ...

  2. 5-14 电话聊天狂人 (25分) HASH

    给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数NN(\le 10^5≤10​5​​),为通话记录条数.随后NN行,每行给出一条通话记录.简单起见,这里只列出 ...

  3. 【PTA 天梯赛训练】电话聊天狂人(简单map)

    输入格式: 输入首先给出正整数N(≤10^5),为通话记录条数.随后N行,每行给出一条通话记录.简单起见,这里只列出拨出方和接收方的11位数字构成的手机号码,其中以空格分隔. 输出格式: 在一行中给出 ...

  4. 7-14 电话聊天狂人(25 分)(Hash表基本操作)

    7-14 电话聊天狂人(25 分) 给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数N(≤10​5​​),为通话记录条数.随后N行,每行给出一条通话记录.简单 ...

  5. PAT-7-14 电话聊天狂人

    ps: 真不明白为什么水题不能一次ac 7-14 电话聊天狂人(25 分) 给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数N(≤10​5​​),为通话记录条 ...

  6. 电话聊天狂人 【STL】

    7-2 电话聊天狂人(25 分) 给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数N(≤10​5​​),为通话记录条数.随后N行,每行给出一条通话记录.简单起 ...

  7. PTA 逆散列问题 (30 分)(贪心)

    题目链接:https://pintia.cn/problem-sets/1107178288721649664/problems/1107178432099737614 题目大意: 给定长度为 N 的 ...

  8. JavaScript数据结构-11.散列

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  9. PTA 01-复杂度2 Maximum Subsequence Sum (25分)

    题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/663 5-1 Maximum Subsequence Sum   (25分) Given ...

随机推荐

  1. java static block

    java 中 静态块的作用 (一)java 静态代码块 静态方法区别一般情况下,如果有些代码必须在项目启动的时候就执行的时候,需要使用静态代码块,这种代码是主动执行的;需要在项目启动的时候就初始化,在 ...

  2. OO作业第一单元总结

    一.第一单元作业回顾 ​ 系列一作业分为三周进行,都是表达式求导,难度渐进. ​ 第一次实现的是简单幂函数的求导,第二次加入了sin和cos两种三角函数,第三次实现了三角函数内的嵌套以及引入了表达式因 ...

  3. java中栈、堆和方法区的关系

    另外,常量池在方法区中

  4. runtime实践之Method Swizzling

    利用 Objective-C 的 Runtime 特性,我们可以给语言做扩展,帮助解决项目开发中的一些设计和技术问题.这一篇,我们来探索一些利用 Objective-C Runtime 的黑色技巧.这 ...

  5. PostgreSQL学习(1)-- 安装pageinspect extension

    1.源码编译 pageinspect的源码在postgre源码包的contrib目录下,解压postgre源码包后进入对应的目录. [root@localhost pageinspect]# pwd ...

  6. SAP行列转换的一种方法

    一段经典的代码写在这里 TABLES spfli. DATA: lt_data TYPE STANDARD TABLE OF spfli, lwa_ref TYPE REF TO data, lt_f ...

  7. docker镜像下载

    获得CentOS的Docker CE 预计阅读时间: 10分钟 要在CentOS上开始使用Docker CE,请确保 满足先决条件,然后 安装Docker. 先决条件 Docker EE客户 要安装D ...

  8. linux三剑客正则表达式

    ^:以...开头,^d,意思是以d开头.例如:ls  -F(-p) | grep " ^d " $:以...结尾,/$,意思是以/结尾.例如:ls -F(-p) | grep &q ...

  9. 一个form表单对应多个submit

    一个form表单多个submit 在平时项目开发过程中,经常会遇到一个form表单对应多个submit提交的情况,那么 ,这种情况应该怎么解决呢,也很简单,这时候就不能用submit来提交了,可以通过 ...

  10. Python基础(三)—— print()格式化输出变量

    先举一个简单的例子说明: name = 'Jack' answer = input('你好,%s '%(name) + '你认识 Sean 不, 输入 yes or no\n') print('Sea ...