PTA数据结构与算法题目集(中文)  7-14

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

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

输入格式:

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

输出格式:

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

输入样例:

4
13005711862 13588625832
13505711862 13088625832
13588625832 18087925832
15005713862 13588625832

输出样例:

13588625832 3

(7-12 是简单的桶排序应用 7-13是排序的应用 至于排序在另一篇博客里写到了)
题目分析:一道利用散列表(哈希表)的基础题 将数据读入后进行判断就可以了 需要注意要记录所有狂人的人数 那么在找到最新的那个狂人时候 将人数设为1 之后找到与他次数相同的认识 将人数加1
 #define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
#include<math.h>
#include<string.h>
#define KEYLENGTH 11
#define MAXTABLESIZE 10000 typedef char ElementType[KEYLENGTH + ];
typedef struct LNode* PtrToLNode;
typedef PtrToLNode List;
struct LNode
{
ElementType Data;
PtrToLNode Next;
int TelTimes;
}; typedef struct HblNode* HashTable;
struct HblNode
{
int TableSize;
List Heads;
}; long Atoi(ElementType Tel)
{
long num = ;
int length = strlen(Tel);
for (int i = ; i < length; i++)
num += num * + Tel[i] - '';
return num;
} int NextPrime(int num)
{
int p = (num % ) ? num + : num + ;
int i;
while (p<MAXTABLESIZE)
{
for (i = (int)sqrt(p); i > ; i--)
if (p % i == )
break;
if (i == )
break;
else
p += ;
}
return p;
} int Hash(ElementType Tel,int TabelSize)
{
return atoi(Tel+) % TabelSize;
} HashTable BuildHashTable(int TabelSize)
{
HashTable H = (HashTable)malloc(sizeof(struct HblNode));
H->TableSize = NextPrime(TabelSize);
H->Heads = (List)malloc(H->TableSize * sizeof(struct LNode));
for (int i = ; i < H->TableSize; i++)
{
H->Heads[i].Data[] = '\0';
H->Heads[i].Next = NULL;
}
return H;
} PtrToLNode Find(ElementType Tel, HashTable H)
{
int i = Hash(Tel,H->TableSize);
PtrToLNode P = H->Heads[i].Next;
while (P && strcmp(P->Data, Tel))
P = P->Next;
return P;
} void Insert(ElementType Tel, HashTable H)
{
PtrToLNode P, NewCell;
P = Find(Tel, H);
if (!P)
{
int i = Hash(Tel, H->TableSize);
NewCell = (PtrToLNode)malloc(sizeof(struct LNode));
strcpy(NewCell->Data, Tel);
NewCell->TelTimes = ;
NewCell->Next = H->Heads[i].Next;
H->Heads[i].Next = NewCell;
}
else
P->TelTimes++;
} HashTable CreateHashTable()
{
int N;
scanf("%d", &N);
HashTable H = BuildHashTable(N);
N *= ;
while (N--)
{
ElementType Tel;
scanf("%s", Tel);
Insert(Tel, H);
}
return H;
}
void Judge(HashTable H)
{
int TelTimes = -;
PtrToLNode MinP=NULL;
PtrToLNode P=NULL;
int Persons = ;
for (int i = ; i < H->TableSize; i++)
{
P = H->Heads[i].Next;
while (P)
{
if (P->TelTimes > TelTimes)
{
Persons = ;
MinP = P;
TelTimes = P->TelTimes;
}
else if (P->TelTimes == TelTimes)
Persons++;
P = P->Next;
}
}
if(Persons==)
printf("%s %d", MinP->Data,MinP->TelTimes);
else
printf("%s %d %d", MinP->Data, MinP->TelTimes,Persons);
} int main()
{
HashTable H = CreateHashTable();
Judge(H);
return ;
}

PTA数据结构与算法题目集(中文) 7-14的更多相关文章

  1. PTA数据结构与算法题目集(中文) 7-43字符串关键字的散列映射 (25 分)

    PTA数据结构与算法题目集(中文)  7-43字符串关键字的散列映射 (25 分) 7-43 字符串关键字的散列映射 (25 分)   给定一系列由大写英文字母组成的字符串关键字和素数P,用移位法定义 ...

  2. PTA数据结构与算法题目集(中文) 7-42整型关键字的散列映射 (25 分)

    PTA数据结构与算法题目集(中文)  7-42整型关键字的散列映射 (25 分) 7-42 整型关键字的散列映射 (25 分)   给定一系列整型关键字和素数P,用除留余数法定义的散列函数将关键字映射 ...

  3. PTA数据结构与算法题目集(中文) 7-41PAT排名汇总 (25 分)

    PTA数据结构与算法题目集(中文)  7-41PAT排名汇总 (25 分) 7-41 PAT排名汇总 (25 分)   计算机程序设计能力考试(Programming Ability Test,简称P ...

  4. PTA数据结构与算法题目集(中文) 7-40奥运排行榜 (25 分)

    PTA数据结构与算法题目集(中文)  7-40奥运排行榜 (25 分) 7-40 奥运排行榜 (25 分)   每年奥运会各大媒体都会公布一个排行榜,但是细心的读者发现,不同国家的排行榜略有不同.比如 ...

  5. PTA数据结构与算法题目集(中文) 7-39魔法优惠券 (25 分)

    PTA数据结构与算法题目集(中文)  7-39魔法优惠券 (25 分) 7-39 魔法优惠券 (25 分)   在火星上有个魔法商店,提供魔法优惠券.每个优惠劵上印有一个整数面值K,表示若你在购买某商 ...

  6. PTA数据结构与算法题目集(中文) 7-38寻找大富翁 (25 分)

    PTA数据结构与算法题目集(中文)  7-38寻找大富翁 (25 分) 7-38 寻找大富翁 (25 分)   胡润研究院的调查显示,截至2017年底,中国个人资产超过1亿元的高净值人群达15万人.假 ...

  7. PTA数据结构与算法题目集(中文) 7-37 模拟EXCEL排序 (25 分)

    PTA数据结构与算法题目集(中文)  7-37 模拟EXCEL排序 (25 分) 7-37 模拟EXCEL排序 (25 分)   Excel可以对一组纪录按任意指定列排序.现请编写程序实现类似功能. ...

  8. PTA数据结构与算法题目集(中文) 7-36 社交网络图中结点的“重要性”计算 (30 分)

    PTA数据结构与算法题目集(中文)  7-36 社交网络图中结点的“重要性”计算 (30 分) 7-36 社交网络图中结点的“重要性”计算 (30 分)   在社交网络中,个人或单位(结点)之间通过某 ...

  9. PTA数据结构与算法题目集(中文) 7-35 城市间紧急救援 (25 分)

    PTA数据结构与算法题目集(中文)  7-35 城市间紧急救援 (25 分) 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市 ...

  10. PTA数据结构与算法题目集(中文) 7-34

    PTA数据结构与算法题目集(中文)  7-34 7-34 任务调度的合理性 (25 分)   假定一个工程项目由一组子任务构成,子任务之间有的可以并行执行,有的必须在完成了其它一些子任务后才能执行.“ ...

随机推荐

  1. 原生ajax动态添加数据

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. mysql 如果没有密码 就不能远程连接

    mysql 如果没有密码 就不能远程连接

  3. 【作业1.0】OO第一单元作业总结

    OO第一单元作业已全部完成,为了使这一单元的作业能够收获更多一点,我回忆起我曾经在计算机组成课设中,经常我们会写一些实验报告,经常以此对实验内容反思总结.在我们开始下一单元的作业之前,我在此对OO第一 ...

  4. greenplum数据库常用操作

    1. 场景描述 greenplum集群部署好后,软件老王在实际使用过程中碰到一些问题,简单记录下,希望能帮到有需要的朋友. 2 .解决方案 2.1 gpcc监控地址 说明:非常重要,greenplum ...

  5. javascript异步上传图片文件

    html: <form action="url" enctype="multipart/form-data" id="myform"  ...

  6. 网维大师重建B盘方法

    [操作步骤]操作前先熟悉步骤,以免手忙脚乱.请在人少的时候操作. 1.打开网维大师安装目录,进入barserver\找到barserver.ini打开,找到[PlatformUpdate]字段下的up ...

  7. [最短路,floyd] Codeforces 1202B You Are Given a Decimal String...

    题目:http://codeforces.com/contest/1202/problem/B B. You Are Given a Decimal String... time limit per ...

  8. [贪心]Codeforces Equal Rectangles

    Equal Rectangles time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...

  9. angularjs中$parse的用法

    转载自:https://umur.blog/2014/02/25/advanced-angular-parse/ 高级Angular:$ parse 如果你想加强你的AngularJS知识,$ par ...

  10. 【问题解决】-《java.lang.NoClassDefFoundException》

    此问题相比与ClassNotFoundException,不容易找到,当然这两者都属于jvm加载类时的错误.导致 NoClassDefFoundException的原因:编译时不报错,运行时在内存中找 ...