标签:
Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 16049 Accepted Submission(s): 5154

题目大意:给你n个数,让你判断出现最多的那个数字的次数是多少。由于所给数字有几十位,long long也存不下。所以采用Hash记录每个数,同时记录次数。 由于所给的n个数会有00001这种带前缀0的数据,所以要先处理一下。
#include<stdio.h>
#include<algorithm>
#include<string.h>
#include<iostream>
using namespace std;
const int maxn = 1e4+200;
struct Chain{
char st[200];
int tm;
Chain *next;
Chain(){
tm = 0;
next = NULL;
}
~Chain(){
}
}Hash_Table[maxn];
int ans;
//BKDR
int Hash(char *s){
unsigned int seed = 131; //13,131,1313 13131 131313
unsigned int v_hash = 0;
while(*s == ‘0‘){
++s;
}
while(*s){
v_hash = v_hash * seed + (*s++);
}
return (v_hash & 0x7fffffff);
}
void Insert(Chain *rt, char *s){
while(*s == ‘0‘) s++;
printf("%s\n",s);
while(rt -> next != NULL){
rt = rt->next;
if(strcmp(rt->st,s)==0){
rt->tm++;
ans = max(ans,rt->tm);
return ;
}
}
rt->next = new Chain();
rt = rt->next;
rt->next = NULL;
strcpy(rt->st,s);
rt->tm++;
ans = max(ans,1);
}
void Free(Chain * rt){
if(rt->next != NULL)
Free(rt->next);
{
delete rt;
}
}
int main(){
char s[maxn];
int n, m;
unsigned int H;
while(scanf("%d",&n)!=EOF){
ans = 0;
for(int i = 1; i <= n; ++i){
scanf("%s",s);
H = Hash(s)%2911;
// printf("%u+++++++++++\n",H);
Insert(&Hash_Table[H],s);
}
printf("%d\n",ans);
for(int i = 0; i <= 3200; i++){
if(Hash_Table[i].next == NULL) continue;
Free(Hash_Table[i].next);
Hash_Table[i].next = NULL;
}
}
return 0;
}
/*
5
000
0001
00000
0
1
4
10
0010
00010
11
*/
HDU 1800——Flying to the Mars——————【字符串哈希】
标签:
原文地址:http://www.cnblogs.com/chengsheng/p/5359104.html