首页 > 其他 > 详细

leetcode 101. 对称二叉树

时间:2021-06-14 23:37:24      阅读:28      评论:0      收藏:0      [点我收藏+]

一、题目

给定一个二叉树,检查它是否是镜像对称的。

例如,二叉树 [1,2,2,3,4,4,3] 是对称的。

    1
   /   2   2
 / \ / 3  4 4  3

但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的:

    1
   /   2   2
   \      3    3

二、解法

有两种方法:递归和迭代。
判断两棵子树 \(p\),\(q\) 是否是对称的:首先要判断根节点,然后判断 \(p.left\)\(q.right\) 是否是对称的,以及 \(p.right\)\(q.left\) 是否是对称的。

递归:

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    boolean check(TreeNode p,TreeNode q){
        if(p==null&&q==null){
            return true;
        }
        if((p==null&&q!=null)||(p!=null&&q==null)){
            return false;
        }
        return p.val==q.val&&check(p.left,q.right)&&check(p.right,q.left);
    }

    public boolean isSymmetric(TreeNode root) {
        return check(root.left,root.right);
    }
}

迭代:
使用队列保存值。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public boolean isSymmetric(TreeNode root) {
        Queue<TreeNode> que=new LinkedList<TreeNode>();
        que.offer(root.left);
        que.offer(root.right);
        while(!que.isEmpty()){
            TreeNode p=que.poll(),q=que.poll();
            if(p==null&&q==null){
                continue;
            }
            if((p==null&&q!=null)||(p!=null&&q==null)||p.val!=q.val){
                return false;
            }
            que.offer(p.left);
            que.offer(q.right);

            que.offer(p.right);
            que.offer(q.left);
        }
        return true;
    }
}

leetcode 101. 对称二叉树

原文:https://www.cnblogs.com/livingsu/p/14883498.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!