Chinaunix

标题: 树的算法求助? [打印本页]

作者: ljt2k    时间: 2010-06-29 14:02
标题: 树的算法求助?
有10000条数字串的记录,如 :
1000
10005
100058
200
201
202
202100
......

另给出一个数字串,要求从上面的列表中,找出是这个指定串的最长的前缀的那个记录?(如果找不到,则返回空)
如给出100058333,则返回100058,而不是返回1000

请问,怎样设计性能最好?
作者: donglongchao    时间: 2010-06-29 14:16
字典树?
作者: shang2010    时间: 2010-06-29 15:27
这个谈不上好性能,in是个流的话

用一个max记录最长前缀大小,pos位置

把整个流穷举一下就可以,,,time O(n);;



如果已经定义好的树,就是尝试贪婪deep最大的树叶子,具体还要看树的定义
作者: 没本    时间: 2010-06-29 16:21
先给需要查找的串,且只有几个的话,可以一遍扫描。

建字典树也是很自然的方法。

对那10000条数据散列也行,收到待查找串按该串长度做二分法散列求值做散列查找。

还可以对10000条数字串排序,收到待查找串后做二分查找。
作者: bandaotidejia    时间: 2010-06-29 16:35
本帖最后由 bandaotidejia 于 2010-06-29 16:40 编辑

因为是排序的,所以需要树,用个红黑排序树即可




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2