字典树查找-----------------------【TrieTree】

结局思想

1  定义结构体数组--------------结构体数组中的内容包含计数器count【作用是用来标记单词的结尾,在查找的时候用于判断 是不是存在所要查找的字符串】;指针数组str_26[26]【此处我所开【此处为了说明原理,我所使用的数组的大小是26,这就意味着只能是全部的大写或者全部的小写,并且不能含有其他的特殊的字符,用户可以根据实际需要开辟数组的大小】;单词的解释str_information【用于记录存放的单词的含义,为了方便处理此处其所加载的注释都是拼音形式的,方便处理】

2  定义创建节点的函数get_Trietree【函数的作用是常见一个节点,节点的类型是1中的一个结构体类型的指针,创建的同时,将结构体中的count初始化为0,指针数组初始化为NULL,str_information初始化为空(初始化的操作使用memset系统函数一步实现)】

3  创建字符串的加载函数add_str【函数的作用是将字典树种的字典树单词全部按照26叉树的形对应的式加载;函数需要的参数分别是26叉树的根节点,字典树的组成的字符串,对用的单词的相应的解释;创建的方法是,由于在结构体中创建的数组的大小是26,所以在操作的时候,使用每一个加载的字符产中的每一个字符的ASCII减去‘’‘a’的ASCII,当然你也可以直接减去97(‘a’对应的ASCII的数值就是97),得到相应的数值后判断在26大小的数组的对应的位置是不是空的,如果是的话,创建新的节点并将节点加载进去,否则的话向下继续便利,知道达到插入的字符串的长度的时候,表明这是数据已经完全插入字典树种,但是为了能够便是当前的位置是一个单词的结尾,需要更新结构体中的count的数值,我做采用的方法是加一操作,此时表示加载字符串结束,结束的同时,将相应的媳妇创对应的解释的信息加载到对应的节点中,操作结束】

4  创建字典树,在查找的函数create_TrieTree【函数的作用是将主函数中加载的字符创数组中的数据加载到字典树种,完成字典树的创建的过程,很具闯入的字符创数组的大小循环加载字符串,知道玩成最富创术组的加载】

5   查找函数find_str【函数的作用是查找字典树种与目标字符串相匹配的字符串,根据要查找的字符串长度的大小作为循环条件进退出循环,进行操作,在查找的时候,从字典树的根节点开始想想进行一步步的比较,知道达到查找的字符串的长度大小的时候结束循环,但是此时的查找并没有结束,当走出循环时需要判断是不是满足字典树种此时的节点是单词的结尾(count!=0),如果是的话表明找到查找的字符串,反之查找失败,在循环的过程中,只要有一个节点的数据与字符串的数据不匹配的情况下,表明在字典树种不存在这个等待查找的字符串】

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct node{
    int count;
    struct node* str_26[26];
    char *str_information;
}TrieTree;

TrieTree  *get_node(){
    TrieTree *root=NULL;
    root=(TrieTree*)malloc(sizeof(TrieTree));
    memset(root,0,sizeof(TrieTree));
    return root;
}

void add_str(TrieTree *root,char *str_1,char *str_2){
    int i=0;
    while(i<strlen(str_1)){
        if(root->str_26[str_1[i]-'a']==NULL){
            root->str_26[str_1[i]-'a']=get_node();
        }
        root=root->str_26[str_1[i]-'a'];
        i++;
    }
    root->count++;
    root->str_information=str_2;
}

TrieTree *create_TrieTree(char *str_1[],char *str_2[],int length){
    if(str_1==NULL || str_2==NULL || length<=0)   return NULL;
    int i;
    TrieTree *root=NULL;
    root=get_node();
    for(i=0;i<length;i++){
        add_str(root,str_1[i],str_2[i]);
    }
    return root;
}

void find_str(TrieTree *root,char *find_str){
    if(root==NULL || find_str==NULL)  return ;
    int i=0;
    while(i<strlen(find_str)){
        if(root->str_26[find_str[i]-'a']==NULL){
            printf("find fail!\n");
            return ;
        }
        root=root->str_26[find_str[i]-'a'];
        i++;
    }
    if(root->count!=0){
        printf("find sucdcessful! find dictionary is: %s\n",root->str_information);
    }
    else{
        printf("find error");
    }
}

int main(){
    TrieTree *root=NULL;
    char *str_1[]={"nice","good","china"};
    char *str_2[]={"feichanghao","haode","zhongguo"};
    root=create_TrieTree(str_1,str_2,3);
    find_str(root,"good");
    return 0;
}
 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值