hdu-统计难题

来源:互联网 发布:数据采集卡的使用 编辑:程序博客网 时间:2024/06/06 07:16

http://acm.hdu.edu.cn/showproblem.php?pid=1251

Problem Description
Ignatius最近遇到一个难题,老师交给他很多单词(只有小写字母组成,不会有重复的单词出现),现在老师要他统计出以某个字符串为前缀的单词数量(单词本身也是自己的前缀).
 

Input
输入数据的第一部分是一张单词表,每行一个单词,单词的长度不超过10,它们代表的是老师交给Ignatius统计的单词,一个空行代表单词表的结束.第二部分是一连串的提问,每行一个提问,每个提问都是一个字符串.

注意:本题只有一组测试数据,处理到文件结束.
 

Output
对于每个提问,给出以该字符串为前缀的单词的数量.
 

Sample Input
bananabandbeeabsoluteacmbabbandabc
 

Sample Output
2310

真心不会啊,真的感觉太难啦,这是别人的代码

一比较好的模板:

#define MAX 26typedef struct Trie{    Trie *next[MAX];//地址域    int v;//数据域};Trie *root;void createTrie(char *str){    int len=strlen(str);    Trie *p=root,*q;    for(int i=0; i<len; ++i)    {        int id=str[i]-'0';        if(p->next[id] == NULL)        {            q=(Trie *)malloc(sizeof(Trie));            q->v = 1;    //初始v==1            for(int j=0; j<MAX; ++j)                q->next[j]=NULL;            p->next[id]=q;            p=p->next[id];        }        else        {            p->next[id]->v++;            p = p->next[id];        }    }    p->v = -1;   //若为结尾,则将v改成-1表示}int findTrie(char *str){    int len = strlen(str);    Trie *p = root;    for(int i=0; i<len; ++i)    {        int id = str[i]-'0';        p = p->next[id];        if(p == NULL)   //若为空集,表示不存以此为前缀的串            return 0;        if(p->v == -1)   //字符集中已有串是此串的前缀            return -1;    }    return -1;   //此串是字符集中某串的前缀}int dealTrie(Trie* T){    int i;    if(T==NULL)        return 0;    for(i=0; i<MAX; i++)    {        if(T->next[i]!=NULL)            deal(T->next[i]);    }    free(T);    return 0;}

代码:

#include<iostream>#include<cstdio>#include<cstring>using namespace std;char a[11];struct node{    int n;    struct node*a[26];    node()    {        n=1;        for(int i=0;i<26;i++)        a[i]=0;    }};node*root;void insert(string&s){    int i;    node*current=root;    for(i=0;i<s.size();i++)    {        if(current->a[s[i]-'a']!=0)        {            current=current->a[s[i]-'a'];            current->n++;        }        else        {            node*code= new node();            current->a[s[i]-'a']=code;            current=code;        }    }}int find(string&s){    int i;    node*current=root;    for(i=0;i<s.size();i++)    {        if(current->a[s[i]-'a']!=0)        {            current=current->a[s[i]-'a'];        }        else        return 0;    }   return current->n;}int main(){    int i,j,k;    root=new node();    string s;    int flag=1;    while(cin.getline(a,11))    {      s=a;      if(s!="")      {          if(flag)          insert(s);          else          printf("%d\n",find(s));      }      else      {          flag=0;      }    }    return 0;}

另:

#include <iostream>#include <cstring>#include <cstdio>#include <cstdlib>using namespace std;struct Trie{  int v;  Trie *next[26];};Trie root;void createTrie(char *str){    int len=strlen(str);    Trie *p=&root,*q;    for(int i=0;i<len;i++)    {        int id=str[i]-'a';        if(p->next[id]==NULL)        {            q=(Trie *)malloc(sizeof(root));            q->v=1;            for(int j=0;j<26;j++)                q->next[j]=NULL;            p->next[id]=q;            p=p->next[id];        }        else        {            p->next[id]->v++;            p=p->next[id];        }    }}int findTrie(char *str){    int len=strlen(str);    Trie *p=&root;    for(int i=0;i<len;i++)    {        int id=str[i]-'a';        p=p->next[id];        if(p==NULL)        {           return 0;        }    }    return p->v;}int main(){    char str[15];    for(int i=0;i<26;i++)    {        root.next[i]=NULL;    }    while(gets(str)&&str[0]!='\0')    {        createTrie(str);    }    while(cin>>str)    {        int ans=findTrie(str);        cout<<ans<<endl;    }    return 0;}



原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 被投诉盗图扣2分怎么办 拼多多盗淘宝图怎么办 微信视频清理了怎么办 牛仔短裤买大了怎么办 淘宝图片打开变大了怎么办 同城换公司社保怎么办 劳务不给交社保怎么办 好多工厂外包工不交社保怎么办 外包公司没有交社保怎么办 外包公司不给交社保怎么办 银行取100万现金怎么办 给老外发警告信后怎么办 照片上传是歪的怎么办 日亚不能直邮的怎么办 电话信息被卖了怎么办 被亚马逊跟卖了怎么办 玉米出芽后土壤不够湿怎么办 雨伞请输入授权码怎么办 网页放手机端后看不了怎么办 微信收款码存在违法行为怎么办 tst优惠码密码忘了怎么办 扩展器登录不上怎么办 微信学法小程序积分不更新怎么办 开发商不给办房产证怎么办 传淘宝产品规格不匹配怎么办 刚买的手机想退怎么办 空调主机空间不足不散热怎么办 lol网速快延迟高怎么办 4g手机延迟高怎么办 天气冷鼻炎就犯怎么办 天气冷宝宝发烧了怎么办 wp手机开机忘记了密码怎么办 微商退货不退款怎么办 微商退货了不退款怎么办 微商退货后不退款怎么办 有赞买东西付款没发货怎么办 赞礼号掉了东西怎么办 万达贷系统维护还不了款怎么办 qq文件发不出去怎么办 1688分销没有传淘宝怎么办 京东的货运代理怎么办