初识树

作者: 发条与小小 | 来源:发表于2018-12-10 10:11 被阅读0次

数据结构中有很多树的结构,其中包括二叉树、二叉搜索树、2-3树、红黑树等等。今天讲最简单的二叉树:

比较重要的相关术语

度(Degree):一个节点拥有的子树数量就是节点的度。
叶子节点(Leaf):度为0的节点。
深度:树中节点的最大层次

二叉树(BinaryTree)

二叉树是数据结构中一种重要的数据结构,也是树表家族最为基础的结构。
二叉树的定义:二叉树的每个结点至多只有二棵子树(不存在度大于2的结点),二叉树的子树有左右之分,次序不能颠倒。二叉树的第i层至多有2i-1个结点;深度为k的二叉树至多有2k-1个结点;对任何一棵二叉树T,如果其终端结点数为n0,度为2的结点数为n2,则n0=n2+1。

image.png

满二叉树和完全二叉树:

满二叉树:除最后一层无任何子节点外,每一层上的所有结点都有两个子结点。也可以这样理解,除叶子结点外的所有结点均有两个子结点。节点数达到最大值,所有叶子结点必须在同一层上。

满二叉树的性质:

  1. 一颗树深度为h,最大层数为k,深度与最大层数相同,k=h;

  2. 叶子数为2h;

  3. 第k层的结点数是:2k-1;

  4. 总结点数是:2k-1,且总节点数一定是奇数。

完全二叉树:若设二叉树的深度为h,除第 h 层外,其它各层 (1~(h-1)层) 的结点数都达到最大个数,第h层所有的结点都连续集中在最左边,这就是完全二叉树。


image.png

他们的 对应关系为一个满二叉树一定是一个完全二叉树,一个完全二叉树不一定是一个满二叉树。

二叉树的遍历

二叉树的遍历分前序遍历(DLR)、中序遍历(LDR)、后序遍历(LRD)。对于二叉树的每个节点而言,遍历都有三个对象,分别是本身、左子、右子,而所谓的前中后,指的就是本身在遍历中的位置,所以前序遍历就是先访问本身,再左右子,中序遍历就是先左子再本身再右子,后序则是先左右子再本身。
关于缩写,我是比较好奇的,D(Degree)L(left child)R(right child)查阅到的英文是这样,暂时这么记。

talk is cheap show me the code(少废话,放码过来)

定义一个二叉树

public class BTreeNode<E> {
    E data;
    BTreeNode<E> left;
    BTreeNode<E> right;

    public BTreeNode(E data, BTreeNode<E> left, BTreeNode<E> right) {
        this.data = data;
        this.left = left;
        this.right = right;
    }
}

遍历方式

     /**
     * 前序遍历
     * */
    public static <E> void dlrTraverse(BTreeNode<E> root){
        if(root == null)
            return;
        println(root.data.toString());
        dlrTraverse(root.left);
        dlrTraverse(root.right);
    }
    /**
     * 中序遍历
     * */
    public static <E> void ldrTraverse(BTreeNode<E> root){
        if(root == null)
            return;
        ldrTraverse(root.left);
        println(root.data.toString());
        ldrTraverse(root.right);
    }
    /**
     * 后序遍历
     * */
    public static <E> void lrdTraverse(BTreeNode<E> root){
        if(root == null)
            return;
        lrdTraverse(root.left);
        lrdTraverse(root.right);
        println(root.data.toString());
    }

本文代码块引用 怀念小兔 代码。

相关文章

  • 初识树

    数据结构中有很多树的结构,其中包括二叉树、二叉搜索树、2-3树、红黑树等等。今天讲最简单的二叉树: 比较重要的相关...

  • 初识枸骨树

    记得有句话说:世界上没有两片相同的叶子。 印象中叶子总是圆形的,可枸骨树的叶片是方天画戟形的[呲牙]。 并且,叶片...

  • 红黑树初识

    为什么需要红黑树? 由于AVL树是以增加增加、删除节点来保证树的基本平衡,从而保证查询效率在O(logN)左右。红...

  • 算法:遍历Dom

    从遍历Dom树,初识算法 参考文章:https://juejin.im/post/6844903731973062...

  • 数据结构与算法(第一季):红黑树

    一、红黑树(Red Black Tree) 1、初识红黑树 红黑树也是一种自平衡的二叉搜索树,也曾叫做平衡二叉B树...

  • 初识哈夫曼树

    何为哈夫曼树: 哈夫曼树是压缩算法中非常重要数据结构。百度百科解释:给定n个权值作为n个叶子节点,构造一棵二叉树,...

  • 初识抽象语法树(AST)

    基本概念 基本字:阿拉伯数字、大小写拉丁字母、其他字符(~、!、%、&、_、-、+、=、{}、[]、:、;、<、>...

  • 数据结构与算法(第一季):B树

    一、B树性质 1、初识B树 B树是一种平衡的多路搜索树,多用于文件系统,数据库的实现。 B树特点:一个节点可以存储...

  • 木棉树

    初识木棉树的时候,很不喜欢。 看着行道树两旁的木棉树, 密密麻麻的刺头着实突兀, 心里倍感恐惧,也纳闷: 这般模样...

  • 这本书文笔一般,却影响了成千上万人

    文:森林树 我喜欢你的书,是因为我更喜欢你。 01 初识艾力,人不聪明文笔不好 初识艾力,是因为《超级演说家》,当...

网友评论

      本文标题:初识树

      本文链接:https://www.haomeiwen.com/subject/nqzlhqtx.html