二叉树,各种树

应用场景
常用二叉树 :AVL树,红黑树,B+树,Trie(字典)树
AVL树:最早平衡二叉树之一,Windows对进程地址空间管理用到了
红黑树:平衡二叉树,广泛用于c++的STL中。如map,set,Linux文件管理是用红黑树实现
B+树:磁盘文件组织 数据索引,数据库索引
Trie(字典)树:统计排序大量字符串。如自动机,M数据库索引

红黑树不能用于MySQL数据库索引
MySQL数据库索引使用b+树 (b树相当于多叉树,b+树是在b树上优化)
原因:1、红黑树深度
2、计算复杂,维护困难。红黑树只能放到硬盘上(放到内存上如果有1千万数据,内存会爆炸),磁盘每次读取只能读取一页数据,红黑树结点物理地址上不相连,磁盘会频繁读取操作。
服务器调优可从内存,CPU,磁盘三方面着手

HashMap为什么不用b+树使用红黑树
b+树放在磁盘的(大量数据)会牵涉到分裂 K,红黑树在内存里(少量数据)
如果数据太少在b+树里可能只有一个点,里面存的是链表了。

二叉查找树,红黑树,b-Tree,b+Tree区别:
二叉查找树(二叉搜索树):优点查找快,某些情况下回退化为链表,是所有高效查找树的基础。
红黑树:内存查找高效树,不适合大数据量,磁盘存储,IO浪费及读取资源浪费,树的深度会很大,适合底层系统做内存运算。
b-Tree:可认为b+tree的过渡。
b+Tree:最适合大数据的磁盘索引,经典MySQL,所有数据都存在叶子节点,其他都是索引,增加了系统稳定性及遍历及查找效率
不同:关键字和key值,数据存储的地方,双向链表。
M阶:由磁盘的页面大小决定,磁盘快和页内存都是4kb。我们节点数及是我们M值应该要尽可能跟他一样。好处是为我们一次刚好能全部拿出一个节点里面存的所有数据。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值