免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1469 | 回复: 4
打印 上一主题 下一主题

树的算法求助? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-06-29 14:02 |只看该作者 |倒序浏览
有10000条数字串的记录,如 :
1000
10005
100058
200
201
202
202100
......

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

请问,怎样设计性能最好?

论坛徽章:
0
2 [报告]
发表于 2010-06-29 14:16 |只看该作者
字典树?

论坛徽章:
154
2022北京冬奥会纪念版徽章
日期:2015-08-07 17:10:5720周年集字徽章-年
日期:2022-10-26 16:44:2015-16赛季CBA联赛之深圳
日期:2022-11-02 14:02:4515-16赛季CBA联赛之八一
日期:2022-11-28 12:07:4820周年集字徽章-20	
日期:2023-07-19 08:49:4515-16赛季CBA联赛之八一
日期:2023-11-04 19:23:5115-16赛季CBA联赛之广夏
日期:2023-12-13 18:09:34
3 [报告]
发表于 2010-06-29 15:27 |只看该作者
这个谈不上好性能,in是个流的话

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

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



如果已经定义好的树,就是尝试贪婪deep最大的树叶子,具体还要看树的定义

论坛徽章:
0
4 [报告]
发表于 2010-06-29 16:21 |只看该作者
先给需要查找的串,且只有几个的话,可以一遍扫描。

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

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

还可以对10000条数字串排序,收到待查找串后做二分查找。

论坛徽章:
0
5 [报告]
发表于 2010-06-29 16:35 |只看该作者
本帖最后由 bandaotidejia 于 2010-06-29 16:40 编辑

因为是排序的,所以需要树,用个红黑排序树即可
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP