免费注册 查看新帖 |

Chinaunix

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

发现红黑树的速度还是没有hashtable的快 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-03-25 16:33 |只看该作者 |倒序浏览
因为PHP的数组是用HashTable写的, 所以我就写了一个用红黑树的结构扩展, 结果运行一看, 查询速度差不多, 但是插入的速度明显慢了很多, 唯一的好处就是内存使用比较少~

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
2 [报告]
发表于 2011-03-25 16:36 |只看该作者
也不能一概而论,总能举出反例的

论坛徽章:
1
CU十二周年纪念徽章
日期:2013-10-24 15:41:34
3 [报告]
发表于 2011-03-25 16:37 |只看该作者
有详细的测试吗?

论坛徽章:
0
4 [报告]
发表于 2011-03-25 16:42 |只看该作者
本帖最后由 liexusong 于 2011-03-25 16:45 编辑

回复 3# ecjtubaowp


    有, 10万数据插入, HashTable需要0.2, 红黑树要0.5

搜索元素HashTable和红黑树都差不多是0.0002左右, 不过红黑树有时候会变化, HashTable基本上不会变~

另外我看过PHP的HashTable, 他还有resize的操作, 所以我觉得resize的消耗可以忽略不计的~

论坛徽章:
1
射手座
日期:2013-08-21 13:11:46
5 [报告]
发表于 2011-03-25 16:45 |只看该作者
红黑树是log(n)的时间复杂度,HashTable是O(1).

论坛徽章:
0
6 [报告]
发表于 2011-03-25 16:46 |只看该作者
本帖最后由 liexusong 于 2011-03-25 16:49 编辑

回复 5# egmkang


    但是HashTable有碰撞啊~ 所以也不是O(1)的~

另外, 红黑树是按算法导论实现的, 所以应该还是可以的

论坛徽章:
1
射手座
日期:2013-08-21 13:11:46
7 [报告]
发表于 2011-03-25 16:58 |只看该作者
回复  egmkang


    但是HashTable有碰撞啊~ 所以也不是O(1)的~

另外, 红黑树是按算法导论实现的,  ...
liexusong 发表于 2011-03-25 16:46


HashTable的优势在于快速查找,通过好的HashCode算法,可以快速的找到那个节点.

论坛徽章:
0
8 [报告]
发表于 2011-03-25 17:02 |只看该作者
很正常啊,哈希的插入和查找过程差不多,不需要额外的操作,
但是rbtree插入时,需要进行旋转,慢一点是可以理解的

10万的数据,rbtree的比较最坏情况在14次左右,但是哈希最坏情况下,估计也不会超过10吧?

论坛徽章:
0
9 [报告]
发表于 2011-03-25 17:04 |只看该作者
嗯, 所以内存足的时候, HashTable是最好用的, 算法简单而且快

论坛徽章:
0
10 [报告]
发表于 2011-03-25 17:07 |只看该作者
树插入元素 有个遍历的过程...
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP