leetcode刷题记录-965. 单值二叉树

90 阅读2分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第1天,点击查看活动详情

前言

今天的题目为简单,简单题,主要是需要遍历二叉树,遍历二叉树的方法有很多,本文主要使用了深度优先搜索的方法来遍历,广度优先搜索可以使用队列实现,有兴趣的伙伴能够进行尝试。

每日一题

今天的题目是 965. 单值二叉树,难度为简单

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

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

 

示例 1:

image.png

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

示例 2:

image.png

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

 

提示:

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

题解

看到题目就知道我们需要去遍历这颗树,那么遍历树比较常见的方法有两种,深度优先搜索和广度优先搜索,深度优先搜索可以使用递归来实现,广度优先搜索可以使用队列来实现。

本文主要使用深度优先搜索来实现这道题

深度优先搜索

结合递归来实现深度优先搜索,要进行递归,那么我们就要优先来分析边界条件,在每一次递归的过程中,我们能够获得的是当前节点的值,以及当前节点的左孩子或者右孩子的值,那么目的就很明显了,在每一次的递归,我们需要去判断当前节点和左右孩子的值是否相等:

  1. 当前结点没有val,那么不存在对比也就不会有不相等的情况,直接返回true

  2. 当前结点有val,但是没有左孩子或者右孩子,那么也无法进行比较,返回true

  3. 当前节点有val,并且有右孩子而且有值,那么右孩子和当前val进行对比,并且要将右孩子进入再次递归当中

  4. 当前节点有val,并且有左孩子而且有值,那么左孩子和当前val进行对比,并且要将左孩子进入再次递归当中

/**
 * Definition for a binary tree node.
 * function TreeNode(val, left, right) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.left = (left===undefined ? null : left)
 *     this.right = (right===undefined ? null : right)
 * }
 */
/**
 * @param {TreeNode} root
 * @return {boolean}
 */
var isUnivalTree = function(root) {
     if (!root) {
        return true;
    }
    if (root.left && root.val !== root.left.val) {
        return false; 
    }
    if (root.right && root.val !== root.right.val) {
        return false;
    }
    if(!isUnivalTree(root.left) || !isUnivalTree(root.right)){
         return false;
    }
    return true;
};

image.png