【Java数据结构】二叉树的实现

1、二叉树基本概念:二叉树是每个节点最多有两个子树的有序树。通常子树的根被称作“左子树”和“右子树”。

2、二叉树的单个结点:左子树、右子树、值。

class TreeNode {//一个结点的构造方法
    public char val;
    public TreeNode left;
    public TreeNode right;
    public TreeNode (char val) {
        this.val = val;
    }
}

3、二叉树:为了方便调试,我们用简单方法建立一个二叉树,该二叉树如下图所示。

public class BinaryTree {
    public TreeNode createTree() {
        TreeNode A = new TreeNode('A');
        TreeNode B = new TreeNode('B');
        TreeNode C = new TreeNode('C');
        TreeNode D = new TreeNode('D');
        TreeNode E = new TreeNode('E');
        TreeNode F = new TreeNode('F');
        TreeNode G = new TreeNode('G');
        TreeNode H = new TreeNode('H');
        A.left = B;
        A.right = C;
        B.left = D;
        B.right = E;
        C.left = F;
        C.right = G;
        E.right = H;
        return A;
    }

4、二叉树的前中后序遍历:每次把根结点的左右子树当作新的根节点递归遍历,当根节点为空时说明此时已经达到了树的尽头。

    void preOrder(TreeNode root) {//前序遍历,遍历顺序根左右,每次遇到根节点时打印,遍历到根节点为空时返回,
        if(root == null) {
            return;
        }
        System.out.print(root.val + " ");
        preOrder(root.left);
        preOrder(root.right);
    }
    void inOrder(TreeNode root) {//中序遍历
        if(root == null) {
            return;
        }
        inOrder(root.left);
        System.out.print(root.val + " ");
        inOrder(root.right);
    }
    void postOrder(TreeNode root) {//后序遍历
        if(root == null) {
            return;
        }
        postOrder(root.left);
        postOrder(root.right);
        System.out.print(root.val + " ");
    }

5、求所有结点:①遍历:在方法外定义一个变量count=0,每当递归一次时如果root不为0,那么这个结点就存在,此时count++②子问题:每次递归返回size0(root.left) + size0(root.right) + 1

    int count = 0;
    int size(TreeNode root) {//遍历求所有结点的方法
        if (root == null) {
            return 0;
        }
        count ++;
        size(root.left);
        size(root.right);
        return count;
    }
    int size0(TreeNode root) {//子问题求所有结点的方法
        if (root == null) {
            return 0;
        }
        return size0(root.left) + size0(root.right) + 1;//
    }

6、求所有叶子结点:和求所有结点类似,但是要判断这个结点的孩子结点是否都为空,是的话这个结点就是叶子结点。

int leaf = 0;
    int getLeafNodeCount(TreeNode root) {//遍历求叶子结点的方法
        if (root == null) {
            return 0;
        }
        if (root.left == null && root.right == null) {
            leaf ++;
        }
        getLeafNodeCount(root.left);
        getLeafNodeCount(root.right);
        return leaf;
    }
    int getLeafNodeCount0(TreeNode root) {//子问题求叶子结点的方法
        if(root == null) {
            return 0;
        }
        if (root.left == null && root.right == null) {
            return 1;
        }
        return getLeafNodeCount0(root.left) + getLeafNodeCount0(root.right);
    }

7、求第k层的结点个数:

    int getKLevelNodeCount(TreeNode root, int k ) {//求k层结点的个数
        if (root == null || k < 1) {//终止条件①当这棵树没有子树无法继续,②当这棵树有子树但是已经到k了没必要继续
            return 0;
        }
        if (k == 1) {//根据规律,当K=1时说明达到了给出的条件
            return 1;
        }
        return getKLevelNodeCount(root.left, k - 1) + getKLevelNodeCount(root.right, k - 1);
     }
     int getHeight(TreeNode root) { //获取二叉树的高度
        if (root == null) {
            return 0;
        }
        return (getHeight(root.left) > getHeight(root.right)) ? getHeight(root.left) + 1: getHeight(root.right) + 1;
     }

8、值为value的结点是否存在:

     TreeNode find(TreeNode root, char value) {//值为value的元素是否存在
        if (root == null) {
            return null;
        }
        if (root.val == value) {
            return root;
        }
        TreeNode ret = find(root.left, value);
        if (ret != null) {
            return ret;
        }
        ret = find(root.right, value);
        if (ret != null) {
            return ret;
        }
        return null;
     }

9、是否为完全二叉树: 判断是否为完全二叉树,将二叉树左右两边的结点放入队列,队列每次弹出一个元素,此元素不为空则将他的两个孩子结点放入队列,继续执行循环弹出下一个元素,最后会得到一个队列,如果队列里有非空元素则不是完全二叉树。

     boolean isCompleteTree(TreeNode root) {//判断是否为完全二叉树,将二叉树左右两边的结点放入队列,队列每次弹出一个元素。
        if (root == null) return true;      //此元素不为空则将他的两个孩子结点放入队列,继续执行循环弹出下一个元素。
        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(root);
        TreeNode cur;
        int size = size(root);
        while (!queue.isEmpty()) {
            cur = queue.poll();
            if (cur != null) {

                queue.offer(cur.left );
                queue.offer(cur.right);
            } else {
                break;
            }
        }
        while (!queue.isEmpty()) {//最后判断队列里如果有不为空的元素那么不是完全二叉树
            if (!(queue.poll() == null)) {
                return false;
            }
        }
        return true;
     }

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
二叉树是一种常见的数据结构,它由节点组成,每个节点最多有两个子节点:左子节点和右子节点。以下是一个简单的Java实现二叉树的例子: ```java // 定义二叉树节点类 class TreeNode { int val; TreeNode left; TreeNode right; public TreeNode(int val) { this.val = val; this.left = null; this.right = null; } } // 构建二叉树 public class BinaryTree { TreeNode root; public BinaryTree(int val) { this.root = new TreeNode(val); } // 插入节点 public void insert(int val) { TreeNode newNode = new TreeNode(val); if (root == null) { root = newNode; } else { TreeNode current = root; TreeNode parent; while (true) { parent = current; if (val < current.val) { current = current.left; if (current == null) { parent.left = newNode; return; } } else { current = current.right; if (current == null) { parent.right = newNode; return; } } } } } // 先序遍历 public void preOrderTraversal(TreeNode node) { if (node != null) { System.out.print(node.val + " "); preOrderTraversal(node.left); preOrderTraversal(node.right); } } // 中序遍历 public void inOrderTraversal(TreeNode node) { if (node != null) { inOrderTraversal(node.left); System.out.print(node.val + " "); inOrderTraversal(node.right); } } // 后序遍历 public void postOrderTraversal(TreeNode node) { if (node != null) { postOrderTraversal(node.left); postOrderTraversal(node.right); System.out.print(node.val + " "); } } } // 创建二叉树并进行遍历 public class Main { public static void main(String[] args) { BinaryTree binaryTree = new BinaryTree(5); binaryTree.insert(3); binaryTree.insert(7); binaryTree.insert(2); binaryTree.insert(4); binaryTree.insert(6); binaryTree.insert(8); System.out.println("先序遍历结果:"); binaryTree.preOrderTraversal(binaryTree.root); System.out.println(); System.out.println("中序遍历结果:"); binaryTree.inOrderTraversal(binaryTree.root); System.out.println(); System.out.println("后序遍历结果:"); binaryTree.postOrderTraversal(binaryTree.root); System.out.println(); } } ``` 这个例子展示了如何构建一个二叉树,并对其进行先序、中序和后序遍历。你可以根据需要修改节点的值和插入顺序来构建不同的二叉树

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值