树的算法求助?
时间:2010-06-29
来源:互联网
有10000条数字串的记录,如 :
1000
10005
100058
200
201
202
202100
......
另给出一个数字串,要求从上面的列表中,找出是这个指定串的最长的前缀的那个记录?(如果找不到,则返回空)
如给出100058333,则返回100058,而不是返回1000
请问,怎样设计性能最好?
1000
10005
100058
200
201
202
202100
......
另给出一个数字串,要求从上面的列表中,找出是这个指定串的最长的前缀的那个记录?(如果找不到,则返回空)
如给出100058333,则返回100058,而不是返回1000
请问,怎样设计性能最好?
作者: ljt2k 发布时间: 2010-06-29
字典树?
作者: donglongchao 发布时间: 2010-06-29
这个谈不上好性能,in是个流的话
用一个max记录最长前缀大小,pos位置
把整个流穷举一下就可以,,,time O(n);;
如果已经定义好的树,就是尝试贪婪deep最大的树叶子,具体还要看树的定义
用一个max记录最长前缀大小,pos位置
把整个流穷举一下就可以,,,time O(n);;
如果已经定义好的树,就是尝试贪婪deep最大的树叶子,具体还要看树的定义
作者: shang2010 发布时间: 2010-06-29
先给需要查找的串,且只有几个的话,可以一遍扫描。
建字典树也是很自然的方法。
对那10000条数据散列也行,收到待查找串按该串长度做二分法散列求值做散列查找。
还可以对10000条数字串排序,收到待查找串后做二分查找。
建字典树也是很自然的方法。
对那10000条数据散列也行,收到待查找串按该串长度做二分法散列求值做散列查找。
还可以对10000条数字串排序,收到待查找串后做二分查找。
作者: 没本 发布时间: 2010-06-29
本帖最后由 bandaotidejia 于 2010-06-29 16:40 编辑
因为是排序的,所以需要树,用个红黑排序树即可
因为是排序的,所以需要树,用个红黑排序树即可
作者: bandaotidejia 发布时间: 2010-06-29
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28