题目描述:
在美丽大兴安岭原始森林中存在数量繁多的物种,在勘察员带来的各种动物资料中有未统计数量的原始动物的名单。科学家想判断这片森林中哪种动物的数量最多,但是由于数据太过庞大,科学家终于忍受不了,想请聪明如你的ACMer来帮忙。
输入描述:
第一行输入动物名字的数量N(1<= N <= 10000),接下来的N行输入N个字符串表示动物的名字(字符串的长度不超过10,字符串全为小写字母,并且只有一组测试数据)。
输出描述:
输出这些动物中最多的动物的名字与数量,并用空格隔开(数据保证最多的动物不会出现两种以上)。
样例输入:
复制
10 boar pig sheep gazelle sheep sheep alpaca alpaca marmot mole
样例输出:
sheep 3
提示:
没有提示哦
来源:
张云聪 陈玉【原创】
数组模拟
#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
using namespace std;
#define maxn 200010
int tree[maxn][26],sum[40001];
int tot,n,rt,len;
bool v[40001];
char s[15];
void insert_()
{
len=strlen(s);
rt=0;
for(int i=0;i<len;i++)
{
int id=s[i]-'a';
if(!tree[rt][id])
tree[rt][id]=++tot;
rt=tree[rt][id];
}
v[rt]=true;sum[rt]++;
}
int search_()
{
rt=0;
len=strlen(s);
for(int i=0;i<len;i++)
{
int id=s[i]-'a';
if(!tree[rt][id])
return 0;
rt=tree[rt][id];
}
if(v[rt]==true)
return sum[rt];
}
int main()
{
int t;int MM=0;
char ss[25];
scanf("%d",&t);
memset(v,false,sizeof(v));
for(int i=0;i<t;i++)
{
scanf("%s",s);
insert_();
int sum1=search_();
if(sum1>MM)
{
MM=sum1;
strcpy(ss,s);
}
}
printf("%s %d\n",ss,MM);
return 0;
}
动物统计加强版(字典树)指针
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<iostream>
using namespace std;
char flag[12];//用来记录出现次数最多的字符串
struct node
{
node *next[26];//node类的26个子类
int count;//每一个类终端的个数
node()//构造函数,用来初始化数据
{
memset(next,0,sizeof(next));
count=0;
}
};
int MAX;//用来记录最出现次数
node *root=new node();//声明一个初始node类 (这个类决定了以下所有子类,是字典树的根)
void insert(char *s)//建立字典树
{
node *p=root;
int i,k;
for(int i=0;s[i];i++)
{
k=s[i]-'a';
if(p->next[k]==NULL)
p->next[k]=new node();//不存在此节点则创建
p=p->next[k];//移向下一个节点
}
p->count++;
if(p->count>MAX)//更新MAX和flag
{
MAX=p->count;
strcpy(flag,s);
}
}
//void findtrie(char *s)
//{
// node *p=root;
// int l=strlen(s);
// for(int i=0;i<l;i++)
// {
// if(p->next[s[i]-'a']==NULL)
// {
// printf("0\n");
// return;
// }
// p=p->next[s[i]-'a'];
//
// }
// printf("%d\n",p->count);
//}
//void del(node *root)//释放内存
//{
// for(int i=0;i<10;i++)
// {
// if(root->next[i])
// del(root->next[i]);
// }
// delete(root);
//}
int main()
{
int t;char s[15];
scanf("%d",&t);
while(t--)
{
scanf("%s",s);
insert(s);
}
printf("%s %d\n",flag,MAX);
return 0;
}