poj-2503 字典树

#include <stdio.h>  
#include <stdlib.h>  
#include <string.h>  
struct Node  
{  
    char low[11];//存放最终的字符串   
    Node *next[26];//26个英文字母指针   
};
Node *root,*p,*q;  
void Init(Node *root)//初始化   
{  
    root->low[0]='#';//'#'表示没有存储字符串       
    for(int i=0;i<26;i++)  
        root->next[i]=NULL;  
}  
void BuildTire(char *s2,char *s1)  
{  
    int i,v;  
    for(i=0,p=root;i<strlen(s2);i++)  
    {  
        v=s2[i]-'a';    
        if(p->next[v]==NULL)//v节点为空 
        {  
            q=(struct Node*)malloc(sizeof(Node));  
            Init(q);  
            p->next[v]=q;  
        }  
        p=p->next[v]; //p移动 
    }  
    strcpy(p->low,s1);  
}  
Node *Insearch(char *str)  
{  
    int i,v;  
    for(i=0,p=root;i<strlen(str);i++)  
    {  
        v=str[i]-'a';  
        if(p->next[v]==NULL)  
            break;  
        p=p->next[v];  
    }  
    return p;  
}  
int main()  
{  
    char str[23],s1[11],s2[11];  
    root=(struct Node *)malloc(sizeof(Node));  
    Init(root);  
    while(gets(str) && str[0]!='\0')  
    {  
        sscanf(str,"%s%s",s1,s2);  
        BuildTire(s2,s1);  
    }  
    while(gets(str) && str[0]!='\0')  
    {  
        Node *r=Insearch(str);  
        if(r->low[0]!='#')  
            printf("%s\n",p->low);  
        else  
            printf("eh\n");  
    }  
    return 0;  
}  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值