持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第1天,点击查看活动详情
前言
今天的题目为简单,简单题,主要是需要遍历二叉树,遍历二叉树的方法有很多,本文主要使用了深度优先搜索的方法来遍历,广度优先搜索可以使用队列实现,有兴趣的伙伴能够进行尝试。
每日一题
今天的题目是 965. 单值二叉树,难度为简单
-
如果二叉树每个节点都具有相同的值,那么该二叉树就是单值二叉树。
-
只有给定的树是单值二叉树时,才返回 true;否则返回 false。
示例 1:
输入:[1,1,1,1,1,null,1]
输出:true
示例 2:
输入:[2,2,2,5,2]
输出:false
提示:
- 给定树的节点数范围是 [1, 100]。
- 每个节点的值都是整数,范围为 [0, 99] 。
题解
看到题目就知道我们需要去遍历这颗树,那么遍历树比较常见的方法有两种,深度优先搜索和广度优先搜索,深度优先搜索可以使用递归来实现,广度优先搜索可以使用队列来实现。
本文主要使用深度优先搜索来实现这道题
深度优先搜索
结合递归来实现深度优先搜索,要进行递归,那么我们就要优先来分析边界条件,在每一次递归的过程中,我们能够获得的是当前节点的值,以及当前节点的左孩子或者右孩子的值,那么目的就很明显了,在每一次的递归,我们需要去判断当前节点和左右孩子的值是否相等:
-
当前结点没有val,那么不存在对比也就不会有不相等的情况,直接返回true
-
当前结点有val,但是没有左孩子或者右孩子,那么也无法进行比较,返回true
-
当前节点有val,并且有右孩子而且有值,那么右孩子和当前val进行对比,并且要将右孩子进入再次递归当中
-
当前节点有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;
};