PTA 11-散列1 电话聊天狂人 (25分)
题目地址
https://pta.patest.cn/pta/test/15/exam/4/question/722
5-14 电话聊天狂人 (25分)
给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人。
输入格式:
输入首先给出正整数NN(\le 10^5≤105),为通话记录条数。随后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分)的更多相关文章
- PTA 5-14 电话聊天狂人 (25分)
给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数NN(\le 10^5≤105),为通话记录条数.随后NN行,每行给出一条通话记录.简单起见,这里只列出 ...
- 5-14 电话聊天狂人 (25分) HASH
给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数NN(\le 10^5≤105),为通话记录条数.随后NN行,每行给出一条通话记录.简单起见,这里只列出 ...
- 【PTA 天梯赛训练】电话聊天狂人(简单map)
输入格式: 输入首先给出正整数N(≤10^5),为通话记录条数.随后N行,每行给出一条通话记录.简单起见,这里只列出拨出方和接收方的11位数字构成的手机号码,其中以空格分隔. 输出格式: 在一行中给出 ...
- 7-14 电话聊天狂人(25 分)(Hash表基本操作)
7-14 电话聊天狂人(25 分) 给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数N(≤105),为通话记录条数.随后N行,每行给出一条通话记录.简单 ...
- PAT-7-14 电话聊天狂人
ps: 真不明白为什么水题不能一次ac 7-14 电话聊天狂人(25 分) 给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数N(≤105),为通话记录条 ...
- 电话聊天狂人 【STL】
7-2 电话聊天狂人(25 分) 给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数N(≤105),为通话记录条数.随后N行,每行给出一条通话记录.简单起 ...
- PTA 逆散列问题 (30 分)(贪心)
题目链接:https://pintia.cn/problem-sets/1107178288721649664/problems/1107178432099737614 题目大意: 给定长度为 N 的 ...
- JavaScript数据结构-11.散列
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 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 ...
随机推荐
- mysql 忘记root密码的解决办法
1.修改MySQL的登录设置: # vim /etc/my.cnf 在[mysqld]的段中加上一句:skip-grant-tables 例如: [mysqld] datadir=/var/lib/m ...
- C# 使用解析json 嵌套方法
C#从网页不传参数 接收json数据 public String GetHtmlFromUrl(String url) { //Response.Write(url); //Response.End( ...
- Android商城开发系列(一)——开篇
最近在看尚硅谷的硅谷商城视频,想系统学习一下Android的商城开发流程,打算跟着视频的一步步做出一个商城,然后写博客总结记录一下整个商城的开发过程以及使用到的技术知识点,这个商城的最终效果如下图所示 ...
- servlet forword服务器端跳转
web.xml中配置servlet的映射和访问路径 <?xml version="1.0" encoding="UTF-8"?><web-ap ...
- UWP开发:存储容器设置&复合设置数据
有时候为了将应用设置进行分类,需要创建新的容器进行存储应用设置的信息. 1,容器的创建:在一个根容器里嵌套一个新容器 1)首先获取根容器. 2)调用ApplicationDataContainer.C ...
- 远程桌面连接(mstsc)无法断开的解决方案
某2008 r2有二个系统账户,同时允许两个tcp连接,但每个用户仅同时允许一人登录.不知何因,关闭远程桌面连接的窗口后,再次连接就瞬间提示无法被连接.查看了事件查看器,信息为被注销,这是因为设置了“ ...
- Codeforces Round #Pi (Div. 2) 567E President and Roads ( dfs and similar, graphs, hashing, shortest paths )
图给得很良心,一个s到t的有向图,权值至少为1,求出最短路,如果是一定经过的边,输出"YES",如果可以通过修改权值,保证一定经过这条边,输出"CAN",并且输 ...
- [论文理解] CornerNet: Detecting Objects as Paired Keypoints
[论文理解] CornerNet: Detecting Objects as Paired Keypoints 简介 首先这是一篇anchor free的文章,看了之后觉得方法挺好的,预测左上角和右下 ...
- Kubernetes之pod的属性
属性名称 取值类型 是否必选 取值说明 version String Required(必) 版本号,例如v1 kind String Required pod m ...
- C++利用偏移量对文件操作
对输入流操作:seekg()与tellg()对输出流操作:seekp()与tellp()下面以输入流函数为例介绍用法: seekg()是对输入文件定位,它有两个参数:第一个参数是偏移量,第二个参数是基 ...