| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 8297 人关注过本帖, 1 人收藏
标题:字典树(已完成遍历、插入、删除整颗树)
只看楼主 加入收藏
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
收藏
得分:0 
回复 40楼 九转星河
先找首字母,然后去对应的树里找单词。
跟我那个链表一样的嘛,只是这里说的是数组,而且数组用下标更快(好吧,还是那话,其实26个节点的链表的遍历也是飞一样的速度,所以用数组其实快也感觉不出来,但快是肯定的。),直接 *word - 'a' 就可以了。

09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-06-04 20:19
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:25 
这么复杂,每个字母都要对应26个指针,这还仅仅是字母,如果放大到asc字符集、再放大到整个汉字字符集呢?还要在一个节点放置足够多的指针吗?
我觉得还是提取特征值的哈希算法更简明,在有序的字典查询中,32位哈希算法产生的值,碰撞的可能性极小。
2017-06-04 20:21
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
收藏
得分:0 
回复 42楼 xzlxzlxzl
不复杂啊,我在主题贴的第一行就说了啊,占用很大。

如果插入单词较少,的确占用很大,但我实际测试(读取一个639kb的文本),占用没有想象中的那么大,可惜找不到更大的英文文本来测试。

汉字的问题不考虑,我现在连宽字符都还没去看。

而且这个程序真的有实用价值吗?我表示怀疑,但是……当想到一个东西的时候,先实现,再考虑其他不适更好?

[此贴子已经被作者于2017-6-4 20:26编辑过]


09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-06-04 20:23
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
回复 42楼 xzlxzlxzl
我当时也考虑到汉字方面的问题~不过当时没有把这个问题放大罢了~用一张足够大的哈希当然可以解决问题~不过光32位的哈希已经大得无伦了~

不过我想到了可以把哈希表先改小一点~碰撞的话再另外开多一张哈希表~这就有<<哈希表的值是另一个哈希表>>了~当然人为精心设计的哈希碰撞还是不可避免的~


[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-06-04 20:35
快速回复:字典树(已完成遍历、插入、删除整颗树)
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015058 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved