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

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

一、题目解析



通过示例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;
    }
}

相关推荐
Tutankaaa4 分钟前
知识竞赛题库设计全攻略
人工智能·算法
天空属于哈夫克39 分钟前
企业微信API常见的错误和解决方案
java·数据库·企业微信
WolfGang00732131 分钟前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
摇滚侠1 小时前
VMvare 虚拟机 Oracle19c 安装步骤,远程连接 Oracle19c,百度网盘安装包
java·oracle
梁萌1 小时前
idea报错找不到XX包的解决方法
java·intellij-idea·启动报错·缺少包
Agent产品评测局1 小时前
生产排期与MES/ERP系统打通,实操方法详解 —— 2026企业级智能体自动化选型与实战指南
java·运维·人工智能·ai·chatgpt·自动化
阿丰资源1 小时前
基于Spring Boot的电影城管理系统(直接运行)
java·spring boot·后端
呱牛do it2 小时前
企业级门户网站设计与实现:基于SpringBoot + Vue3的全栈解决方案(Day 8)
java
aini_lovee2 小时前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab
消失的旧时光-19432 小时前
Spring Boot 工程化进阶:统一返回 + 全局异常 + AOP 通用工具包
java·spring boot·后端·aop·自定义注解