给定一棵二叉树,判断琪是否是自身的镜像(即:是否对称)两种方法递归与迭代

判断二叉树是否对称

http://www.nowcoder.com/questionTerminal/1b0b7f371eae4204bc4a7570c84c2de1

import java.util.*;

/*
 * public class TreeNode {
 *   int val = 0;
 *   TreeNode left = null;
 *   TreeNode right = null;
 * }
 */

public class Solution {
    /**
     * 
     * @param root TreeNode类 
     * @return bool布尔型
     */
      public boolean isSymmetric(TreeNode root) {
        return checkMetric(root, root);
    }

    private boolean checkMetric(TreeNode root1, TreeNode root2) {
        if (root1 == null && root2 == null)
            return true;
        if ((root1 != null && root2 == null) || root1 == null && root2 != null)
            return false;
        return (root1.val == root2.val && checkMetric(root1.left, root2.right) && checkMetric(root1.right, root2.left));
    }
}
// 非递归,利用层次遍历,但是要注意左右入队次序;
        if (root == null)
            return true;
        Queue<TreeNode> queue = new LinkedList<TreeNode>();
        if (root.left == null || root.right == null) {
            return root.left == root.right;
        }
        queue.add(root.left);
        queue.add(root.right);
        while (queue.size() > 0) {
            TreeNode lefTreeNode = queue.poll();
            TreeNode rigtheTreeNode = queue.poll();
            if ((lefTreeNode == null && rigtheTreeNode != null) || (lefTreeNode != null && rigtheTreeNode == null)) {
                return false;
            } else if (lefTreeNode == null && rigtheTreeNode == null) {
                continue;
            } else if (lefTreeNode.val != rigtheTreeNode.val) {
                return false;
            }
            queue.add(lefTreeNode.left);
            queue.add(rigtheTreeNode.right);
            queue.add(lefTreeNode.right);
            queue.add(rigtheTreeNode.left);
        }
        return true;
    }
全部评论

相关推荐

魔法恐龙:这真得给个机会,面试的时候问问不吃饭78.5h怎么做到的
点赞 评论 收藏
分享
2025年初,新的一年开始,我给自己暗暗打气,发誓今年一定要拿到offer。如今2025年即将结束,找工作仍然没有任何水花,如今的失意和落魄和年初信心满满的姿态形成鲜明对比,想必也是因为被社会毒打,认清现实了吧。先分享一下贴主的背景,本人女,本科末流985文科专业,后来保送到华五,成绩一直是班级第一,有过国奖,实习有多段头部大厂经历。发贴的直接原因是今天华为面试挂,在反思中有很多复杂的想法,包括对自身能力的怀疑、对面试官所提问题的不解、对大环境的无奈。贴主是一个说话温柔、不喜欢咄咄逼人、有点社恐的人(基本上算是人们眼中对小女生的刻板印象,所以在历次群面中基本全挂(看到大家争抢当leader、t...
在找内推的小虾米:感觉这一段经历和我好像啊,前段时间面了很多车企,面试项目经历各种被拷打,大多数都没过一面,最有希望拿offer的一个终面挂了把我干破防了,打电话给爸妈哭了一个多小时才缓过来。我也开始否定自己,否定自己的一切,包括性格,能力,成长经历。。。最后面了深圳的某家公司,面试官人都挺友好,提的问题有深度但找到切入点 ,最后hr也按岗位最高的标准给的offer,我才发现自己并没有这么不堪,只是我的能力和经验和之前的岗位要求不那么符合而已。帖主一定不要灰心,招聘的窗口期还有很长很长,保持自信扬长避短,一定有企业能发现你的闪光点,祝好。
我的求职进度条
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务