2022.2.20 LeetCode —— 二叉树


一、今日刷题

1. 第六部分:哈希表 – 101. 对称二叉树

跳转LeetCode

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

在这里插入图片描述


答案代码

方法一:递归
通过递归函数的返回值来判断两个子树的内侧节点和外侧节点是否相等。遍历两棵树而且要比较内侧和外侧节点,所以准确的来说是一个树的遍历顺序是左右中,一个树的遍历顺序是右左中。

package BinaryTree;

/**
 * @author: LYZ
 * @date: 2022/2/20 14:05
 * @description: 101.给你一个二叉树的根节点 root , 检查它是否轴对称。
 */
public class IsSymmetric {
    public static void main(String[] args) {
        TreeNode root = new TreeNode(1, new TreeNode(2, new TreeNode(3), new TreeNode(4)), new TreeNode(2, new TreeNode(4), new TreeNode(3)));
        IsSymmetric isSymmetric = new IsSymmetric();
        boolean ans = isSymmetric.isSymmetric(root);
        System.out.println(ans);
    }

    public boolean isSymmetric(TreeNode root) {
        if (root == null) {
            return true;
        }
        boolean ans = compare(root.left, root.right);
        return ans;
    }

    boolean compare(TreeNode left, TreeNode right) {
        if (left == null && right != null) {
            return false;
        } else if (left != null && right == null) {
            return false;
        } else if (left == null && right == null) {
            return true;
        } else if (left.val != right.val) {
            return false;
        }

        boolean outside = compare(left.left, right.right);
        boolean inside = compare(left.right, right.left);
        boolean ans = outside && inside; //注意这里,最开始写的是 outside == inside,当两者都为 false 时也会返回 true,太蠢了

        return ans;
    }
}

方法二:迭代
首先我们引入一个队列,这是把递归程序改写成迭代程序的常用方法。 初始化时我们把根节点入队两次。每次提取两个结点并比较它们的值(队列中每两个连续的结点应该是相等的,而且它们的子树互为镜像),然后将两个结点的左右子结点按相反的顺序插入队列中。当队列为空时,或者我们检测到树不对称(即从队列中取出两个不相等的连续结点)时,该算法结束。

(其实就是把左右两个子树要比较的元素顺序放进一个容器,然后成对成对的取出来进行比较)

class Solution {
    public boolean isSymmetric(TreeNode root) {
        return check(root, root);
    }

    public boolean check(TreeNode u, TreeNode v) {
        Queue<TreeNode> q = new LinkedList<TreeNode>();
        q.offer(u);
        q.offer(v);
        while (!q.isEmpty()) {
            u = q.poll();
            v = q.poll();
            if (u == null && v == null) {
                continue;
            }
            if ((u == null || v == null) || (u.val != v.val)) {
                return false;
            }

            q.offer(u.left);
            q.offer(v.right);

            q.offer(u.right);
            q.offer(v.left);
        }
        return true;
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值