【数据结构】_7.二叉树概念与基本操作

这篇具有很好参考价值的文章主要介绍了【数据结构】_7.二叉树概念与基本操作。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1.树形结构

1.1 树的概念

1.2 树的相关概念

1.3 树的表示

1.4 树在实际中的应用—表示文件系统的目录树结构

​编辑​2.二叉树

2.1 概念

2.2 特殊二叉树

 2.3 二叉树的性质

2.4 二叉树的存储结构

2.4.1 顺序存储结构(数组存储结构)

2.4.2 链式存储结构

2.5 二叉树的基本操作

2.5.1 二叉树的深度优先遍历

2.5.2 二叉树的广度优先遍历

2.5.3 二叉树的结点统计

2.5.4 二叉树的叶子结点统计

 2.5.5 二叉树第K层结点统计

 2.5.6 获取二叉树的高度

2.5.7 检测值为value的元素是否存在

2.5.8 判断一棵树是否为完全二叉树

2.6 二叉树的非递归方法

2.6.1 非递归实现前序遍历

2.6.2 非递归实现中序遍历

2.6.3 非递归实现后序遍历


1.树形结构

1.1 树的概念

树是一种非线性数据结构,它是由n(n>0)个有限结点组成一个具有层次关系的集合,把它称为树是因为它看起来像一棵倒挂的树,根在上,枝叶在下。

① 根节点是一个没有前驱结点的特殊结点;

② 除根节点外,其余结点被分为M(M>0)个互不相交的集合T1,T2,T3...Tm,其中每一个集合Ti(1<=i<=m)又是一棵结构与树类型相似的子树,每棵树的根节点有且仅有一个前驱,可以有0个或多个后继;

③ 因此,树是递归定义的;

PS:树形结构中,子树之间不能有交集,即除了根节点之外,每个结点有且仅有一个直接前驱;

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

1.2 树的相关概念

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

(1)结点的度:一个结点含有的子树的个数,如A结点的度为6;

(2)叶结点或终端结点:度为0的结点,如H、I、P、Q、K、L、M、N;

(3)非终端结点或分支结点:度不为0的结点,如:D、E、F、G、J;

(4)双亲结点或父节点:含有子结点的结点,称该结点为其子结点的父结点,如A是B的父结点;

(5)孩子结点或子结点:一个结点含有的子树的根节点称为该结点的子结点,如B是A的子结点;

(6)兄弟结点:具有相同父结点的结点,如B和C是兄弟结点;

(7)数的度:一棵树中最大的结点的度称为数的度,如上图树的度为6;

(8)结点的层次:从根开始定义,根为第一层,根的子结点为第二层,以此类推;

(9)树的高度或深度:树中结点的最大层次,如上图树的高度或深度为4;

(10)堂兄弟结点:双亲在同一层的结点称为堂兄弟,如H和I互为堂兄弟结点;

(11)结点的祖先:从根到该结点所经分支上的所有结点,如A是所有结点的祖先;

(12)子孙:以某节点为根的子树中任一结点都成为该结点的子孙,如所有节点都是A的子孙;

(13)森林:由m(m>0)棵互不相交的树的集合称为森林;

1.3 树的表示

树的存储相较于线性表要复杂得多,既要存储值域,也要存储结点与结点之间的关系;

树有很多种表达方式,如双亲表示法、孩子表示法、孩子-双亲表示法。

最常用的是:左孩子-右兄弟表示法。

图示:

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

 代码表示:

class Node{
    int val;     // 数据域
    Node firstChild;   // 第一个孩子引用
    Node nextBrother;  // 下一个兄弟引用
}
//注意此处的兄弟指的是亲兄弟而非堂兄弟,即此处指向的兄弟有相同的祖先

1.4 树在实际中的应用—表示文件系统的目录树结构

​2.二叉树

2.1 概念

(1)一个二叉树的结点是一个有限集合,该集合:① 或者为空 ② 有一个根节点加上两个别称为左子树和右子树的二叉树组成;

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

 (2)特点:

    ① 不存在度大于2的结点;

    ② 二叉树的子树有左右之分,次序不能颠倒,因此二叉树是有序树;

(3)任意一种二叉树都是由①空树②只有根节点③只存在左子树④只存在右子树⑤左右子树均存在这五种情况复合而成;

2.2 特殊二叉树

(1)满二叉树:

 每层节点数都是最大值的二叉树,即满足层数为k,结点总数是2^k-1的二叉树就是完全二叉树。

(2)完全二叉树:

对于深度为k的二叉树,前k-1层的结点都是满的,最后一层不满但满足,存在的结点是从左向右是连续的

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

 2.3 二叉树的性质

(1)若规定根结点层数为1,则一棵非空二叉树的第i层上最多有2^(i-1)个结点

(2)若规定根结点层数为1,则深度为h的二叉树的最大结点数是2^k-1

(3)对任何一个二叉树,如果度为0的结点个数为n0,度为2的分支节点个数为n2,则有n0=n2+1;

(4)若规定根节点的层数为1,具有n个结点的满二叉树的深度,h=log2(n+1)(以2为底);

例1:某二叉树共有399个结点,其中199个度为2的结点,则该二叉树中的叶子节点数为(B)

A.不存在这样的二叉树   B.200    C.198   D. 199   

解析:根据第三条性质,叶子结点数即度为0的结点数,根据第三条性质得答案。

例2:在具有2n个结点的完全二叉树中,叶子结点个数为(A)

A.n  B.n+1 C. n-1  D.n/2

解析:度为0的结点记为n0,度为1的结点记为n1,度为2的结点记为n2,根据题意有:

n0+n1+n2=2n,结合第三条性质有:n2=n0-1,代入有2*n0-1+n1=2n,对于一个完全二叉树来

说,度为1的结点只能有0个或1个,此处若n1=0,则n0为小数,故而n1只能为1,所以度为0的结

点个数为n。

例3:一个完全二叉树结点数为531个,那么这棵树的高度为(B)

A.11 B. 10  C.8  D.12

解析:高度为h的完全二叉树,结点范围是[2^(h-1),2^h-1],代入选项进行上下限计算得答案。

例4:一个具有767个结点的完全二叉树,其叶子结点个数为(B)

A.383  B. 384  C.385  D.386

解析略,同例二思路

2.4 二叉树的存储结构

二叉树的存储有两种存储方式:

2.4.1 顺序存储结构(数组存储结构)

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

① 一般使用数组存储只适合表示完全二叉树或满二叉树,若是一般二叉树会存在很多空间浪费;

在现实使用中,只有对才会使用数组来存储;

② 二叉树的顺序存储在物理上是一个数组,在逻辑上是一个二叉树。

③ 同时顺序存储可以根据下标计算结点父子关系:

知父求子:leftchild=parent*2+1,leftchild=parent*2+2;

知子求父:(parent-1)/2;

2.4.2 链式存储结构

二叉树的链式存储是通过一个一个的结点引用起来的,常见的表示方式有:

(1)二叉表示法(孩子表示法):

class Node{
    int val;   // 数据域
    Node left;   // 左孩子引用(常代表以左孩子为根的整个左子树)
    Node right;  // 右孩子引用(常代表以右孩子为根的整个右子树)
}

 (2)三叉表示法(孩子-双亲表示法):

class Node{
    int val;   // 数据域
    Node left;   // 左孩子引用(常代表以左孩子为根的整个左子树)
    Node right;  // 右孩子引用(常代表以右孩子为根的整个右子树)
    Node parent; // 当前结点的根节点
}

 孩子-双亲表示法主要应用在平衡树,本文采取孩子表示法构建二叉树;

2.5 二叉树的基本操作

2.5.1 二叉树的深度优先遍历

深度优先遍历包括前序遍历、中序遍历与后序遍历;

前序遍历:访问根结点的操作发生在遍历其左右子树之前;(跟->左子树->右子树)

中序遍历:访问根结点的操作发生在遍历其左右子树之中;(左子树->根->右子树)

后序遍历:访问根结点的操作发生在遍历其左右子树之后;(左子树->右子树->根)

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

以#表示空:

前序遍历:1 2 3 # # # 4 5 # # 6 # # 

中序遍历:# 3 # 2 # 1 # 5 # 4 # 6 # 

后序遍历:# # 3 # 2  # # 5 # # 6 4 1

基于以下二叉树结构:

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

其递归实现代码如下:

    // 前序遍历:根  左子树  右子树  递归
    public void preOrder(TreeNode root){
        if(root == null){
            return;
        }
        System.out.print(root.val+"  ");
        preOrder(root.left);
        preOrder(root.right);
    }
    // 中序
    public void inOrder(TreeNode root){
        if(root == null){
            return;
        }
        inOrder(root.left);
        System.out.print(root.val+"  ");
        inOrder(root.right);
    }
    // 后序
    public void postOrder(TreeNode root){
        if(root == null){
            return;
        }
        postOrder(root.left);
        postOrder(root.right);
        System.out.print(root.val+"  ");
    }

创建对象后分别调用,输出结果为:

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java  

注:除过空返回值的写法外,也可以令深度优先遍历有返回值:

(1)遍历思路写法:

    List<Character> ret = new ArrayList<>();
    public List<Character> preorderTraversal(TreeNode root){
        if(root == null){
            return ret;
        }
        ret.add(root.val);
        preorderTraversal(root.left);
        preorderTraversal(root.right);
        return ret;
    }

(2)子问题思路写法:

    public List<Character> preorderTraversal(TreeNode root){
        List<Character> ret = new ArrayList<>();
        if(root == null){
            return ret;
        }
        //System.out.print(root.val+" ");
        ret.add(root.val);

        List<Character> leftTree = preorderTraversal(root.left);
        ret.addAll(leftTree);

        List<Character> rightTree = preorderTraversal(root.right);
        ret.addAll(rightTree);
        return ret;
    }

2.5.2 二叉树的广度优先遍历

创建一个队列,令cur从root开始遍历,在根节点不为空的条件下,将root入队列,依次判断root.left和root.right是否为空,非空则入队列,当队列不为空时,出栈对首元素并令root = cur;

    public void levelOrder(TreeNode root){
        if(root == null){
            return;
        }
        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(root);
        while(!queue.isEmpty()){
            TreeNode cur = queue.poll();
            System.out.print(cur.val+" ");
            if(cur.left != null){
                queue.offer(cur.left);
            }
            if(cur.right != null){
                queue.offer(cur.right);
            }
        }
    }

输出结果为:

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java  

2.5.3 二叉树的结点统计

(1)思路1:子问题思路:

    public int size(TreeNode root){
        // 左树结点+右树结点+根节点
        // 写法1:
        //return root == null? 0: size(root.left)+size(root.right)+1;
        // 写法2:
        if(root == null){
            return 0;
        }
        int leftSize = size(root.left);
        int rightSize = size(root.right);
        return leftSize + rightSize + 1;
    }

(2)思路2:遍历思路:

    public int nodeSize;
    public void size2(TreeNode root){
        if(root == null){
            return;
        }
        nodeSize++;
        size2(root.left);
        size2(root.right);
    }

测试代码为:

        System.out.println("子问题思路求二叉树结点:");
        System.out.println(binaryTree.size(binaryTree.root));
        System.out.println("遍历思路求二叉树结点:");
        binaryTree.size2(binaryTree.root);
        System.out.println(binaryTree.nodeSize);

输出结果为:

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

2.5.4 二叉树的叶子结点统计

(1)思路1:子问题思路:

    public int getLeafNodeCount(TreeNode root){
        if(root == null){
            return 0;
        }
        if(root.left==null && root.left == null){
            return 1;
        }
        int leftTreeNode = getLeafNodeCount(root.left);
        int rightTreeNode = getLeafNodeCount(root.right);
        return leftTreeNode+rightTreeNode;
    }

(2)思路2:遍历思路:

    public int leafNode = 0;
    public void getLeafNodeCount2(TreeNode root){
        if(root == null){
            return;
        }
        if(root.left == null && root.right == null){
            leafNode++;
        }
        getLeafNodeCount2(root.left);
        getLeafNodeCount2(root.right);
    }

测试代码为:

        System.out.println("子问题思路求叶子节点的个数为:");
        System.out.println(binaryTree.getLeafNodeCount(binaryTree.root));
        System.out.println("遍历思路求叶子结点个数为:");
        binaryTree.getLeafNodeCount2(binaryTree.root);
        System.out.println(binaryTree.leafNode);

输出结果为:

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

 2.5.5 二叉树第K层结点统计

(仅展示子问题思路)

    public int getKLevelNodeCount(TreeNode root, int k){
        if(root == null){
            return 0;
        }
        if(k==1){
            return 1;
        }
        int leftTreeNode = getKLevelNodeCount(root.left,k-1);
        int rightTreeNode = getKLevelNodeCount(root.right,k-1);
        return leftTreeNode+rightTreeNode;
    }

测试代码为:

        TestBinaryTree binaryTree = new TestBinaryTree();
        binaryTree.root = binaryTree.createTree();
        System.out.println("请输入要查询结点的层数:");
        Scanner scanner = new Scanner(System.in);
        int k = scanner.nextInt();
        System.out.println("第"+k+"层结点数为:");
        System.out.println(binaryTree.getKLevelNodeCount(binaryTree.root,k));

输出结果为:
【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

 2.5.6 获取二叉树的高度

    public int getHeight(TreeNode root){
        // 二叉树高度是左右子树高度的较大值+1
        if(root==null){
            return 0;
        }
        int leftTreeHeight = getHeight(root.left);
        int rightTreeHeight = getHeight(root.right);
        return (leftTreeHeight>rightTreeHeight)?leftTreeHeight+1:rightTreeHeight+1;
    }

测试代码为:

        TestBinaryTree binaryTree = new TestBinaryTree();
        binaryTree.root = binaryTree.createTree();
        System.out.println("当前二叉树高度为:");
        System.out.println(binaryTree.getHeight(binaryTree.root));

输出结果为:

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

2.5.7 检测值为value的元素是否存在

    public TreeNode find(TreeNode root, char val){
        // 前序遍历二叉树
        if(root == null){
            return null;
        }
        if(root.val == val){
            return root;
        }
        TreeNode leftTree = find(root.left, val);
        if(leftTree != null){
            return leftTree;
        }
        TreeNode rightTree = find(root.right, val);
        if(rightTree != null){
            return rightTree;
        }
        return null;
    }

测试代码为:

        TestBinaryTree binaryTree = new TestBinaryTree();
        binaryTree.root = binaryTree.createTree();
        System.out.println("请输入要查询的value值:");
        char value = (char)System.in.read();
        TestBinaryTree.TreeNode ret = binaryTree.find(binaryTree.root, value);
        if(ret != null){
            System.out.println(ret.val);
        }else {
            System.out.println(ret);
        }

输出结果为·:
【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java     【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java 

2.5.8 判断一棵树是否为完全二叉树

创建一个队列,在根结点不为空的前提下,先将根结点入队列,然后每弹出一个队首元素,就将其左右孩子结点入队列,直到队首元素为空,若此时队列中元素全为空,则为完全二叉树,否则就不是完全二叉树;

代码:

    public boolean isCompleteTree(TreeNode root){
        if(root == null){
            return true;
        }
        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(root);     // 将根结点入队列
        while( !queue.isEmpty()) {
            // 每弹出一个队首元素,就将该元素的左右孩子入队列;
            TreeNode cur = queue.poll();
            if (cur != null) {
                queue.offer(cur.left);
                queue.offer(cur.right);
            } else {
                //  一直出队列队首元素直至队首元素为null
                break;
            }
        }
        
        while(!queue.isEmpty()){
            TreeNode tmp = queue.poll();
            if(tmp != null){
                return false;
            }
        }
        return true;
    }

测试代码为:

        TestBinaryTree binaryTree = new TestBinaryTree();
        binaryTree.root = binaryTree.createTree();
        System.out.println("判断是否为完全二叉树:");
        System.out.println(binaryTree.isCompleteTree(binaryTree.root));
        System.out.println();

输出结果为:
【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

 基于原二叉树,删除E结点的右孩子H结点,再次测试结果如下:
【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java

2.6 二叉树的非递归方法

2.6.1 非递归实现前序遍历

定义cur结点用于遍历二叉树,从根结点root开始,令cur依次遍历左子树,在结点左孩子不为空的前提下,将结点逐个入栈,每入栈一个结点,就打印一个结点,当遇到左孩子为空的结点后,弹出栈顶元素并令cur为其右孩子;

    public void preOrderNor(TreeNode root){
        if(root == null){
            return;
        }
        TreeNode cur = root;
        Deque<TreeNode> stack = new ArrayDeque<>();
        while(cur != null || !stack.isEmpty()) {
            while (cur != null) {
                stack.push(cur);
                System.out.print(cur.val + " ");
                cur = cur.left;
            }
            // 此时为cur为空但栈不为空:
            // 令cur为栈顶元素的右孩子即可
            TreeNode top = stack.pop();
            cur = top.right;
        }
    }

2.6.2 非递归实现中序遍历

    public void inOrderNor(TreeNode root){
        if(root == null){
            return;
        }
        TreeNode cur = root;
        Deque<TreeNode> stack = new ArrayDeque<>();
        while(cur != null || !stack.isEmpty()){
            while(cur != null){
                stack.push(cur);
                cur = cur.left;
            }
            TreeNode top = stack.pop();
            System.out.print(top.val+" ");
            cur = top.right;
        }
    }

2.6.3 非递归实现后序遍历

   public void postOrderNor(TreeNode root){
        if(root == null){
            return;
        }
        TreeNode cur = root;
        TreeNode prev = null;
        Deque<TreeNode> stack = new ArrayDeque<>();
        while(cur != null || !stack.isEmpty()){
            while(cur != null){
                stack.push(cur);
                cur = cur.left;
            }
            TreeNode top = stack.peek();
            if(top.right == null || top.right == prev){
                // 栈顶元素没有右孩子,根据左->右->根,可以直接打印根结点的值
                System.out.print(top.val+" ");
                stack.pop();
                prev = top;
            }else {
                // 栈顶元素有右孩子,还需遍历当前栈顶元素结点的右子树
                cur = top.right;
            }
        }
    }

非递归实现前中后序遍历的测试代码如下:

        TestBinaryTree binaryTree = new TestBinaryTree();
        binaryTree.root = binaryTree.createTree();
        System.out.println("非递归实现前序遍历:");
        binaryTree.preOrderNor(binaryTree.root);
        System.out.println();
        System.out.println("非递归实现中序遍历:");
        binaryTree.inOrderNor(binaryTree.root);
        System.out.println();
        System.out.println("非递归实现后序遍历:");
        binaryTree.postOrderNor(binaryTree.root);
        System.out.println();

 输出结果如下:

【数据结构】_7.二叉树概念与基本操作,数据结构(Java),数据结构,intellij-idea,java文章来源地址https://www.toymoban.com/news/detail-653254.html

到了这里,关于【数据结构】_7.二叉树概念与基本操作的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【数据结构】二叉树的构建与基本操作实现

    👀 樊梓慕: 个人主页   🎥 个人专栏: 《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》 🌝 每一个不曾起舞的日子,都是对生命的辜负 目录 前言 1.前序建立二叉树 2.销毁二叉树 3.统计 4.查找值为x的节点 5.前中后序遍历 6.层序遍历 7.判断二叉树是否

    2024年02月07日
    浏览(45)
  • 【数据结构】二叉树的存储与基本操作的实现

    二叉树的存储结构分为: 顺序存储 和类似于 链表的链式存储 这里博主讲一下链式存储 二叉树的链式存储是通过一个一个的节点引用起来的,常见的表示方式有 二叉和三叉 表示方式 二叉表示: 三叉表示: 这里博主主要讲解一下孩子表示法 在学习二叉树的基本操作前,需

    2024年02月04日
    浏览(48)
  • 数据结构和算法学习记录——初识二叉树(定义、五种基本形态、几种特殊的二叉树、二叉树的重要性质、初识基本操作函数)

    目录 二叉树的定义 二叉树具体的五种基本形态 1.空树 2.只有一个节点 3.有左子树,但右子树为空 4.有右子树,但左子树为空  5.左右两子树都不为空 特殊二叉树 斜二叉树 满二叉树  完全二叉树 二叉树的几个重要性质 初识二叉树的几个操作函数  二叉树T: 一个有穷的节点

    2024年02月03日
    浏览(61)
  • 二叉树的基本操作-C语言实现-数据结构作业

    目录  (1)二叉树的创建; (2)二叉树的先序、中序和后序遍历输出; (3)输出二叉树的叶子节点和度为2的节点的数量; (4)输出二叉树的深度; (5)将二叉树所有节点的左右子树互换(左子树变右子树,右子树变左子树); (6)参考书上,二叉树按层次输出(一行输出一层); (7)删除二

    2024年02月04日
    浏览(48)
  • 数据结构实验报告,二叉树的基本操作(C语言)

    作者:命运之光 专栏:数据结构 实验六 二叉树的基本操作 实验环境:Visual C++或Dev C++ 实验目的: 1、掌握二叉树创建; 2、掌握二叉树的遍历及常用算法。 实验内容: 通过完全前序序列创建一棵二叉树,完成如下功能: 1)输出二叉树的前序遍历序列; 2)输出二叉树的中序遍

    2024年02月09日
    浏览(37)
  • 【数据结构】二叉树的基本概念

    树是一种非线性的数据结构,它是由n(n=0)个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的 子树不能有交集,就是不能有闭环.N个节点两个一条边,所以是N-1个边,父节点的概念在下面讲. 节点的度

    2024年02月08日
    浏览(45)
  • 【数据结构入门】-二叉树的基本概念

    个人主页:平行线也会相交 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 平行线也会相交 原创 收录于专栏【数据结构初阶(C实现)】 今天的内容可是一个大头,比以往学的内容上了一个档次。大家对于这块内容一定要好好学,不是很理解的地方一定要及时解决,要不然到

    2023年04月10日
    浏览(82)
  • 爱上数据结构:二叉树的基本概念

    ​ ​ 🔥个人主页 : guoguoqiang. 🔥 专栏 : 数据结构 ​ 树是一种非线性的数据结构,它是由n(n=0)个有限结点组成一个具有层次关系的集合。把它叫做树是因 为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的。 没有前驱节点的结点叫做根结点 在树中,子树不

    2024年04月14日
    浏览(48)
  • 【数据结构】树和二叉树堆(基本概念介绍)

     🌈个人主页: 秦jh__https://blog.csdn.net/qinjh_?spm=1010.2135.3001.5343 🔥 系列专栏: 《数据结构》https://blog.csdn.net/qinjh_/category_12536791.html?spm=1001.2014.3001.5482 ​​ 目录  前言  树的概念  树的常见名词 树与非树  二叉树 概念 满二叉树和完全二叉树 二叉树的存储结构 顺序存储 链式

    2024年02月01日
    浏览(35)
  • 【数据结构】 二叉树理论概念!一文了解二叉树!

    🎥 屿小夏 : 个人主页 🔥个人专栏 : 数据结构解析 🌄 莫道桑榆晚,为霞尚满天! 什么是二叉树?二叉树的组成构造是什么样的?我们将由浅入深,循序渐进的方式把二叉树给搞明白,让你彻底了解二叉树! 树是一种非线性的数据结构,它是由n(n=0)个有限结点组成一

    2024年02月05日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包