• 算法宝典2——Java版本(此系列持续更新,这篇文章目前3道)(有题目的跳转链接)(此份宝典包含了二叉树的算法题)


    注:由于字数的限制,我打算把算法宝典做成一个系列,一篇文章就20题!!!

    目录

    一、二叉树的算法题(目前3道)

    1. 平衡二叉树(力扣)

    2.  对称二叉树(力扣)

    3. 二叉树的层序遍历(力扣)


    一、二叉树的算法题(目前3道)

    1. 平衡二叉树(力扣)

    题目跳转链接icon-default.png?t=N7T8https://leetcode.cn/problems/balanced-binary-tree/

    题目:给定一个二叉树,判断它是否是高度平衡的二叉树。

    本题中,一棵高度平衡二叉树定义为:一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 ,空树也是平衡二叉树。

    思路:

    代码:

    1. // 获取二叉树的高度
    2. public int maxDepth(TreeNode root){
    3. if(root == null){
    4. return 0;
    5. }
    6. int leftCount = maxDepth(root.left);
    7. int rightCount = maxDepth(root.right);
    8. return (leftCount > rightCount) ? leftCount + 1 : rightCount + 1;
    9. }
    10. //判断是否为平衡二叉树
    11. public boolean isBalanced(TreeNode root) {
    12. //如果为空树,返回null
    13. if(root == null){
    14. return true;
    15. }
    16. //获取左右子树的高度
    17. int leftTreeHigh = maxDepth(root.left);
    18. int righTreeHigh = maxDepth(root.right);
    19. //isBalanced(root.left) && isBalanced(root.left)是判断左右子树是不是也满足平衡二叉树的定义
    20. return Math.abs(leftTreeHigh - righTreeHigh) < 2
    21. && isBalanced(root.left) && isBalanced(root.right);
    22. }

    如果是按照上述代码的思路来写,此算法的时间复杂度就是O(n^2)!!!这是在是太大了!

    什么原因造成的呢?

    答:我们在求3结点的高度时,其实就把9结点的高度求出来了,但是递归到9结点的时候,又求了一次,导致重复求树的高度,有n个结点,每个结点就要求n次高度,也就是n*n!!!

    所以我们可以把代码改一下:

    1. public int maxDepth2(TreeNode root) {
    2. //空树,证明没有子树,他的高度就是0
    3. if(root == null){
    4. return 0;
    5. }
    6. int leftH = maxDepth2(root.left);//只要左子树的高度返回是-1,表示左子树不满足平衡二叉树的定义
    7. if(leftH < 0)
    8. return -1;
    9. int rightH = maxDepth2(root.right);//只要右子树的高度返回是-1,表示左子树不满足平衡二叉树的定义
    10. if (rightH < 0)
    11. return -1;
    12. if(Math.abs(leftH - rightH) <= 1){
    13. return Math.max(leftH,rightH) + 1;//满足定义,返回高度最高的子树,并+1
    14. }else{
    15. return -1;//不满足定义,返回-1
    16. }
    17. }
    18. public boolean isBalanced2(TreeNode root) {
    19. return maxDepth2(root) >= 0;
    20. }

    运行结果:

    2.  对称二叉树(力扣)

    题目跳转链接icon-default.png?t=N7T8https://leetcode.cn/problems/symmetric-tree/

    题目:给你一个二叉树的根节点 root , 检查它是否轴对称。

    思路:

    和这道判断两个二叉树是不是一样的题目类似:算法宝典1——Java版本(此系列持续更新,这篇文章有20道)(有题目的跳转链接)(此份宝典包含了链表、栈、队列、二叉树的算法题)_木子斤欠木同的博客-CSDN博客

    让左子树的左结点和右子树的右子树相比较,然后递归下去,然后就可以判断是不是对称二叉树!!!

    代码:

    1. //判断对称树
    2. public boolean isSymmetricChild(TreeNode leftChild, TreeNode rightChild) {
    3. //这是路径的判断
    4. if (leftChild != null && rightChild == null || leftChild == null && rightChild != null) {
    5. return false;
    6. }
    7. if (leftChild == null && rightChild == null) {
    8. return true;
    9. }
    10. //这是值的判断
    11. if (leftChild.val != rightChild.val) {
    12. return false;
    13. }
    14. return isSymmetricChild(leftChild.left, rightChild.right)
    15. && isSymmetricChild(leftChild.right, rightChild.left);
    16. }
    17. public boolean isSymmetric(TreeNode root) {
    18. if (root == null) {
    19. return true;
    20. }
    21. return isSymmetricChild(root.left,root.right);
    22. }

    运行结果:

    3. 二叉树的层序遍历(力扣)

    题目跳转链接icon-default.png?t=N7T8https://leetcode.cn/problems/binary-tree-level-order-traversal/

    题目:给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。

    思路:

    代码:

    1. //不带链表的形式
    2. public void levelOrder1(TreeNode root){
    3. if(root == null){
    4. return;
    5. }
    6. Queue queue = new LinkedList<>();
    7. queue.offer(root);
    8. while(!queue.isEmpty()){
    9. TreeNode poll = queue.poll();
    10. System.out.println(poll.val+ " ");
    11. if(poll.left != null){
    12. queue.offer(poll.left);
    13. }
    14. if(poll.left != null){
    15. queue.offer(poll.right);
    16. }
    17. }
    18. }
    19. //带链表的形式
    20. public List> levelOrder(TreeNode root) {
    21. List> List = new ArrayList<>();
    22. if(root == null){
    23. return List;
    24. }
    25. Queue queue = new LinkedList<>();
    26. queue.offer(root);
    27. while(!queue.isEmpty()){//第一层循环表示树什么时候遍历完
    28. int size = queue.size();
    29. List list = new ArrayList<>();
    30. while(size != 0){//第二层循环表示当前层次的元素数量
    31. TreeNode cur = queue.poll();
    32. size--;
    33. list.add(cur.val);//将元素保存到列表
    34. if(cur.left != null){
    35. queue.offer(cur.left);
    36. }
    37. if(cur.right != null){
    38. queue.offer(cur.right);
    39. }
    40. }
    41. List.add(list);
    42. }
    43. return List;
    44. }

    运行结果:

  • 相关阅读:
    在 Linux 环境下的简单调试技巧
    linux下安装Prometheus一篇就够了
    python之pyttsx3库实现语音播报
    3.条件概率与独立性
    浮点数(小数)在计算机中如何用二进制存储?
    宝塔显示100%负载100%cpu解决办法
    Msql_流程控制case
    AWS考试认证学习
    谷粒学苑_第三天
    Spring 类级别多属性联合校验&国际化
  • 原文地址:https://blog.csdn.net/ANNE_fly/article/details/132922369