【递归算法】计算布尔二叉树的值

题目链接:计算布尔二叉树的值

一、题目解析



通过示例1我们可以知道大概怎么算了:

先找到最后一层的叶子节点,通过两个叶子节点的双亲结点的值来运算得出布尔值,逐层往上。

二、算法原理

很容易可以想到递归算法,从宏观来说,要想得出布尔二叉树的值:

  • 第一步我们得先知道左孩子的布尔值,
  • 第二步得先知道右孩子的布尔值,
  • 第三步才可以进行运算得出结果。

因此我们可以先递归得出左孩子节点的布尔值,再递归得到右孩子结点的布尔值,最后返回结果即可。

从细节来说,这个顺序很像二叉树的后序遍历,可以自己试着走一遍~

三、代码实现

函数头的设计 :重复的子问题就是得到每一个非叶子节点的布尔值,因此函数头的设计将根节点作为参数即可。

即:

复制代码
boolean dfs(TreeNode root)

函数体的设计:对于每一个节点来说,都要先求出左孩子结点的布尔值和右孩子结点的布尔值,再进行运算,大致如下:

复制代码
boolean left = dfs(root.left);  // 左孩子结点的布尔值
boolean right = dfs(root.right);  // 右孩子结点的布尔值
// 判断root.val并进行布尔运算(可用三目运算符来判断)

递归出口设计:当遇到叶子结点的时候,就返回该节点的布尔值

需要注意的是,数据中存储的是int类型的值,并不是实际的布尔值,因此返回的时候需要加上条件判断。

代码实现如下

Java 复制代码
class Solution {
    public boolean evaluateTree(TreeNode root) {
        // 递归出口
        if (root.left == null) 
            return (root.val == 0) ? false : true;

        // 递归
        boolean left = evaluateTree(root.left);
        boolean right = evaluateTree(root.right);
        return (root.val == 2) ? left | right : left & right;
    }
}

相关推荐
YOU OU14 分钟前
Spring IoC&DI
java·数据库·spring
один but you39 分钟前
从可变参数到 emplace:现代 C++ 性能优化的核心组合
java·开发语言
是码龙不是码农1 小时前
ThreadPoolExecutor 7 个核心参数详解
java·线程池·threadpool
这是程序猿1 小时前
Spring Boot自动配置详解
java·大数据·前端
MY_TEUCK2 小时前
【Java 后端 | Nacos 注册中心】微服务治理原理、选型与注册发现实战
java·开发语言·微服务
m0_629494732 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户2 小时前
用队列实现栈
数据结构·算法
做人求其滴2 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
小江的记录本3 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
daad7773 小时前
记一组无人机IMU传感器数据
算法