记得一年前 跑去CSDN问HDU1251(
http://acm.hdu.edu.cn/showproblem.php?pid=1251)的写法,飞雪写了个很精简的代码,数组模拟字典树。问题是那个代码只适用于那道题目。
后来有道开了一次网络邀请赛,当时就有那么一道字典树的题,我对着它无解。。今天,我去看了一下字典树,仅仅是靠自己理解了一下字典树的图。
图片地址:
http://baike.baidu.com/view/1436495.htm居然就写出了1251,相比与当年飞雪的代码他的时间是46MS 我今天写的是93MS。可是让我开心的是,我觉得我写的这个扩展性强,我似乎有感觉我能解决当年那题有道邀请赛的题目~~好开心呀~~
当年一个人在寝室一个劲的学习链表~~后来很长一段时间觉得链表似乎没什么用。。。直到上次的线段树,现在的trie树,或者以后的红黑树~B树~?呵呵。如果没有链表的基础我不可能只看图就能写出字典树,基础如此的重要。
贴下代码:
1data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
/**//*
2
3957388 2011-05-15 13:59:22 Accepted 1251 93MS 43768K 1163B C++ test
3
so happy learning sth by myself,share this happiness with you ^ ^
4
*/
5data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
6data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
7data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
8
#include <iostream>
9
#include <cstdlib>
10
#include <cstdio>
11
#include <algorithm>
12
#include <cstring>
13
using namespace std;
14data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
15
typedef struct tree
16data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
17
int num;
18
struct tree *br[26];
19
}Node;
20data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
21
void insert(char *str,Node *root) // 插入字典
22data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
23
for(;*str;++str)
24data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
25
int id = *str-'a';
26
if (root->br[id]!=NULL)
27data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
28
root->br[id]->num++;
29
}
30
else
31data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
32
root->br[id] = (Node *)malloc(sizeof(Node));
33
root->br[id]->num=1;
34
for (int j=0;j<26;++j)
35data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
36
root->br[id]->br[j]=NULL;
37
}
38
}
39
root=root->br[id];
40
}
41
}
42data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
43data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
44
int find(char *str,Node *root) // 查找单词数
45data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
46
for(;*str;++str)
47data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
48
int id = *str-'a';
49
if (root->br[id]==NULL)
50data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
51
return 0;
52
}
53
else
54data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
55
if(*(str+1)==0)
56data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
57
return root->br[id]->num;
58
}
59
root=root->br[id];
60
}
61
}
62
return 0;
63
}
64data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
65
void freeM(Node *root) // 释放内存,其实OJ上不释放不影响结果
66data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
67
for(int i=0;i<26;++i)
68data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
69
if(root->br[i]!=NULL)
70data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
71
freeM(root->br[i]);
72
}
73
}
74
free(root);
75
}
76
int main()
77data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
78
char str[10];
79
//freopen("data1.in", "r", stdin);
80
//freopen("data1.out", "w+", stdout);
81
Node *root=(Node *)malloc(sizeof(Node));;
82
int i;
83
for (i=0;i<26;++i)
84data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
85
root->br[i]=NULL;
86
}
87
while (gets(str))
88data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
89
if (str[0]==0)break;
90
insert(str,root);
91
}
92
while (gets(str))
93data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
94
printf("%d\n",find(str,root));
95
}
96
//fclose(stdout);
97
//fclose(stdin);
98
freeM(root);
99
return 0;
100
}
posted on 2011-05-15 14:16
mr_chen 阅读(312)
评论(0) 编辑 收藏 引用 所属分类:
数据结构 、
字典树