news 2026/2/28 5:42:02

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【递归算法】计算布尔二叉树的值

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

一、题目解析




通过示例1我们可以知道大概怎么算了:
先找到最后一层的叶子节点,通过两个叶子节点的双亲结点的值来运算得出布尔值,逐层往上。

二、算法原理

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

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

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

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

三、代码实现

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

boolean dfs(TreeNode root)

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

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

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

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

代码实现如下

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; } }

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/26 19:39:14

智能配置如何引发黑苹果效率革命?从3天到3分钟的技术突破

智能配置如何引发黑苹果效率革命?从3天到3分钟的技术突破 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 黑苹果配置工具的出现&#xff0…

作者头像 李华
网站建设 2026/2/17 15:23:45

OpCore Simplify:从3小时到15分钟的黑苹果EFI配置效率革命

OpCore Simplify:从3小时到15分钟的黑苹果EFI配置效率革命 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 揭示黑苹果配置的核心痛点 在x…

作者头像 李华
网站建设 2026/2/23 22:56:25

技术揭秘:OpCore Simplify如何解决黑苹果EFI配置难题

技术揭秘:OpCore Simplify如何解决黑苹果EFI配置难题 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 在黑苹果生态系统中,Open…

作者头像 李华
网站建设 2026/2/19 5:19:02

OpCore Simplify:零基础一键搞定黑苹果配置的小白专用工具

OpCore Simplify:零基础一键搞定黑苹果配置的小白专用工具 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 你是否也曾梦想在自己的电脑上体…

作者头像 李华
网站建设 2026/2/22 8:15:07

实战应用:用YOLOv9构建智能安防检测原型

实战应用:用YOLOv9构建智能安防检测原型 在工厂巡检、社区出入口、仓库货场等真实安防场景中,开发者常面临一个紧迫问题:如何在3天内交付一个能识别人员闯入、车辆异常停留、安全帽佩戴缺失的可运行检测系统?不是从零配置CUDA环境…

作者头像 李华