news 2026/6/10 3:11:55

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

作者头像

张小明

前端开发工程师

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/6/10 12:54:07

高效管理Buzz模型与自定义模型实践指南:告别繁琐步骤

高效管理Buzz模型与自定义模型实践指南:告别繁琐步骤 【免费下载链接】buzz Buzz transcribes and translates audio offline on your personal computer. Powered by OpenAIs Whisper. 项目地址: https://gitcode.com/GitHub_Trending/buz/buzz 当语音转写出…

作者头像 李华
网站建设 2026/6/10 14:55:13

企业级物联网平台技术选型:PandaX架构解析与实践指南

企业级物联网平台技术选型:PandaX架构解析与实践指南 【免费下载链接】PandaX 🎉🔥PandaX是Go语言开源的企业级物联网平台低代码开发基座,基于go-restfulVue3.0TypeScriptvite3element-Plus的前后端分离开发。支持设备管控&#x…

作者头像 李华
网站建设 2026/6/10 14:52:14

小白也能做专业动画:HY-Motion 1.0零门槛入门指南

小白也能做专业动画:HY-Motion 1.0零门槛入门指南 你是否曾幻想过——不用学骨骼绑定、不用啃Maya教程、甚至不用懂“FK/IK”这些词,只用一句话,就能让3D角色跳起街舞、挥剑劈砍、或是缓缓起身伸个懒腰? 这不是未来预告片&#x…

作者头像 李华
网站建设 2026/6/10 14:55:20

黑苹果配置工具:从入门到精通的自动EFI生成解决方案

黑苹果配置工具:从入门到精通的自动EFI生成解决方案 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 对于许多电脑爱好者来说,安…

作者头像 李华
网站建设 2026/6/10 1:03:33

如何解决视频下载的3大难题:BiliTools深度测评与应用指南

如何解决视频下载的3大难题:BiliTools深度测评与应用指南 【免费下载链接】BiliTools A cross-platform bilibili toolbox. 跨平台哔哩哔哩工具箱,支持视频、音乐、番剧、课程下载……持续更新 项目地址: https://gitcode.com/GitHub_Trending/bilit/B…

作者头像 李华