力扣(LeetCode)单值二叉树 个人题解

如果二叉树每个节点都具有相同的值,那么该二叉树就是单值二叉树。

只有给定的树是单值二叉树时,才返回 true;否则返回 false

 

示例 1:

输入:[1,1,1,1,1,null,1]
输出:true

示例 2:

输入:[2,2,2,5,2]
输出:false

 

提示:

  1. 给定树的节点数范围是 [1, 100]
  2. 每个节点的值都是整数,范围为 [0, 99] 。

 

这题很简单,只要完成遍历二叉树的动作就能解决问题。使用递归完成了前序遍历,每个非空节点的值进行比较是否相同。

(很意外,这题的速度击败了70%的人,内存击败了100%的人)

代码如下:

class Solution {
    int num;

    public boolean isSame(TreeNode root) {
        if(root==null)
            return true;
        if (root.val != num)
            return false;
        else
            return isSame(root.left) && isSame(root.right);    
    }

    public boolean isUnivalTree(TreeNode root) {
        if (root == null)
            return false;
        num = root.val;
        return isSame(root);
    }
}

 

posted @ 2019-03-15 21:02  AXiangCoding  阅读(206)  评论(0编辑  收藏  举报