图解B Tree和B+ Tree

举报
海风极客 发表于 2022/10/16 19:04:46 2022/10/16
【摘要】 图解B Tree和B+ Tree 1 B Tree起源一篇国外的论文:https://infolab.usc.edu/csci585/Spring2010/den_ar/indexing.pdf论文名称为大型有序索引的组织和维护,其中就指出了B Tree这个数据结构其中,B Tree的定义:从根到叶结点的每条路径长度都是h,也称为Tree的高度,即h = 路径中的节点数。除根节点和叶节点外...

图解B Tree和B+ Tree

1 B Tree起源

一篇国外的论文:https://infolab.usc.edu/csci585/Spring2010/den_ar/indexing.pdf

论文名称为大型有序索引的组织和维护,其中就指出了B Tree这个数据结构

其中,B Tree的定义:

  • 从根到叶结点的每条路径长度都是h,也称为Tree的高度,即h = 路径中的节点数。
  • 除根节点和叶节点外,每个节点至少有k -1个儿子。 根至少有两个儿子。
  • 每个节点最多有2k-1个儿子。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-C2NVFGYo-1633403129053)(图解B Tree和B+ Tree.assets/image-20211004113953894.png)]

2 B Tree 数据结构

/**
 * B树数据结构
 */
private static class BTreeNode<K, V> {
    /**
	 * 节点的项,按键非降序存放
	 */
    private List<Entry<K, V>> entries;
    /**
	 * 内节点的子节点
	 */
    private List<BTreeNode<K, V>> children;
    /**
	 * 是否为叶子节点
	 */
    private boolean isLeaf;
    /**
	 * 排序对象
	 */
    private Comparator<K> kComparator;

    private BTreeNode() {
        entries = new ArrayList<>();
        children = new ArrayList<>();
        leaf = false;
    }
    
    /**
     * Entry类
     */
    static class Entry<K, V> {
        private K key;
        private V value;

        public Entry(K k, V v) {
            this.key = k;
            this.value = v;
        }
    }
}

3 图解B Tree

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5ZrHGneL-1633403129055)(图解B Tree和B+ Tree.assets/image-20211004152649336.png)]

4 B+ Tree数据结构

  • 有k个子结点的结点必然有k个关键码;
  • 非叶结点仅具有索引作用,跟记录有关的信息均存放在叶结点中。
  • 树的所有叶结点构成一个有序链表,可以按照关键码排序的次序遍历全部记录。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JN7HnU49-1633403129057)(图解B Tree和B+ Tree.assets/image-20211004152715558.png)]

5 B Tree和B+ Tree对比

B和B+树的区别在于,B+树的非叶子结点只包含导航信息,不包含实际的值,所有的叶子结点和相连的节点使用链表相连,便于区间查找和遍历。

B+ 树的优点在于:

  • 由于B+树在内部节点上不包含数据信息,因此在内存页中能够存放更多的key。 数据存放的更加紧密,具有更好的空间局部性。因此访问叶子节点上关联的数据也具有更好的缓存命中率。
  • B+树的叶子结点都是相链的,因此对整棵树的便利只需要一次线性遍历叶子结点即可。而且由于数据顺序排列并且相连,所以便于区间查找和搜索。而B树则需要进行每一层的递归遍历。相邻的元素可能在内存中不相邻,所以缓存命中性没有B+树好。

子结点即可。而且由于数据顺序排列并且相连,所以便于区间查找和搜索。而B树则需要进行每一层的递归遍历。相邻的元素可能在内存中不相邻,所以缓存命中性没有B+树好。

参考文章:https://blog.csdn.net/fhy569039351/article/details/82976842

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。