【二叉树的深搜】计算布尔二叉树的值 求根节点到叶节点数字之和

ops/2025/1/24 2:32:16/

文章目录

  • 2331. 计算布尔二叉树的值
  • 解题思路:后序遍历
  • 129. 求根节点到叶节点数字之和
  • 解题思路:深度优先搜索 + 前序遍历

在这里插入图片描述

2331. 计算布尔二叉树的值

2331. 计算布尔二叉树的值

给你一棵 完整二叉树 的根,这棵树有以下特征:

  • 叶子节点 要么值为 0 要么值为 1 ,其中 0 表示 False1 表示 True
  • 非叶子节点 要么值为 2 要么值为 3 ,其中 2 表示逻辑或 OR3 表示逻辑与 AND

计算 一个节点的值方式如下:

  • 如果节点是个叶子节点,那么节点的 为它本身,即 True 或者 False
  • 否则,计算 两个孩子的节点值,然后将该节点的运算符对两个孩子值进行 运算

返回根节点 root 的布尔运算值。

完整二叉树 是每个节点有 0 个或者 2 个孩子的二叉树

叶子节点 是没有孩子的节点。

示例 1:

img
输入:root = [2,1,3,null,null,0,1]
输出:true
解释:上图展示了计算过程。
AND 与运算节点的值为 False AND True = False 。
OR 运算节点的值为 True OR False = True 。
根节点的值为 True ,所以我们返回 true 。

示例 2:

输入:root = [0]
输出:false
解释:根节点是叶子节点,且值为 false,所以我们返回 false 。

提示:

  • 树中节点数目在 [1, 1000] 之间。
  • 0 <= Node.val <= 3
  • 每个节点的孩子数为 02
  • 叶子节点的值为 01
  • 非叶子节点的值为 23

解题思路:后序遍历

​ 根据题目的分析,我们对于叶子节点和非叶子节点需要有不同的处理,当我们遍历到叶子节点的时候,其实就可以直接返回 node->val 了,因为此时 0 代表 false1 代表 true,刚刚好和布尔值是一样的,所以我们可以直接返回 node->val 即可!并且因为这道题的二叉树是完整二叉树,也就是一个节点要么左右孩子都存在,要么就是叶子节点,所以我们只需要判断一下 node->left 或者 node->right 存不存在即可判断是否为叶子节点!

​ 而对于非叶子节点,它是逻辑操作,需要有左右子树的计算结果才能执行,所以就得使用后序遍历,先拿到左右子树的计算结果,然后判断一下当前非叶子节点是按位或还是按位与操作,进行不同的返回结果即可!

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:bool evaluateTree(TreeNode* root) {// 递归函数出口if(root->left == nullptr || root->right == nullptr)return root->val;// 先进行后序遍历bool left = evaluateTree(root->left);bool right = evaluateTree(root->right);// 再处理当前节点if(root->val == 2)return left | right;elsereturn left & right;}
};

129. 求根节点到叶节点数字之和

129. 求根节点到叶节点数字之和

给你一个二叉树的根节点 root ,树中每个节点都存放有一个 09 之间的数字。

每条从根节点到叶节点的路径都代表一个数字:

  • 例如,从根节点到叶节点的路径 1 -> 2 -> 3 表示数字 123

计算从根节点到叶节点生成的 所有数字之和

叶节点 是指没有子节点的节点。

示例 1:

img
输入:root = [1,2,3]
输出:25
解释:
从根到叶子节点路径 1->2 代表数字 12
从根到叶子节点路径 1->3 代表数字 13
因此,数字总和 = 12 + 13 = 25

示例 2:

img
输入:root = [4,9,0,5,1]
输出:1026
解释:
从根到叶子节点路径 4->9->5 代表数字 495
从根到叶子节点路径 4->9->1 代表数字 491
从根到叶子节点路径 4->0 代表数字 40
因此,数字总和 = 495 + 491 + 40 = 1026

提示:

  • 树中节点的数目在范围 [1, 1000]
  • 0 <= Node.val <= 9
  • 树的深度不超过 10

解题思路:深度优先搜索 + 前序遍历

​ 因为我们得知道从根节点到每个叶子节点的路径代表的数字和,所以我们就得使用前序遍历来遍历整棵二叉树,在遍历过程中需要有一个变量 tmp 来记录当前走过的路径代表的数。

​ 然后我们只需要判断当前节点是否为叶子节点,是的话直接将最后该叶子节点和 tmp 进行运算后返回给上一层即可;如果不是的话,说明此时还没到可以返回的时机,则递归到左右子树去处理,直到走到叶子节点然后遍历完整棵二叉树为止!

​ 在遍历期间要注意的是我们可以不需要在递归函数开头给出递归函数的出口,因为题目节点个数是大于零的,所以保证一开始是不会访问空指针的,我们只需要在递归左右子树之前判断左右孩子节点是否存在即可,其它的没啥大问题!

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:int sumNumbers(TreeNode* root) {return dfs(root, 0);}int dfs(TreeNode* root, int tmp){// 进行先序遍历处理,只不过是专门对叶子节点处理// 因为题目节点个数是大于零的,所以保证不会访问空指针tmp = tmp*10 + root->val; if(root->left == nullptr && root->right == nullptr)return tmp;// 如果不是叶子节点的话,则继续递归左右子树,并且将左右子树的结果累加到ret上进行返回int ret = 0;if(root->left)  ret += dfs(root->left, tmp);if(root->right) ret += dfs(root->right, tmp);return ret;}
};

​ 这里还有另一种写法,就是我们的递归函数可以不搞返回值,而是用一个变量 sum 来记录路径代表数的总和,要注意的是形参是一个地址或者引用,这样子才能保证全局累加的时候是对同一个 sum 进行累加!

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:int sumNumbers(TreeNode* root) {int sum = 0;dfs(root, 0, sum);return sum;}void dfs(TreeNode* root, int tmp, int& sum){// 进行先序遍历处理,只不过是专门对叶子节点处理sum += tmp*10 + root->val;if(root->left == nullptr && root->right == nullptr)return;if(root->left)  dfs(root->left, tmp*10 + root->val, sum);if(root->right) dfs(root->right, tmp*10 + root->val, sum);}
};

在这里插入图片描述


http://www.ppmy.cn/ops/152627.html

相关文章

深度解析:CentOS 系统的硬件资源优化技巧

深度解析:CentOS 系统的硬件资源优化技巧 在运维的世界中,硬件资源的高效利用是保障系统性能和稳定性的关键。尤其是在使用CentOS这样的服务器操作系统时,优化硬件资源不仅能提升系统响应速度,还能显著降低运营成本。今天,我将结合实际经验,详细介绍如何在CentOS系统中进…

计算机网络 (49)网络安全问题概述

前言 计算机网络安全问题是一个复杂且多维的领域&#xff0c;它涉及到网络系统的硬件、软件以及数据的安全保护&#xff0c;确保这些元素不因偶然的或恶意的原因而遭到破坏、更改或泄露。 一、计算机网络安全的定义 计算机网络安全是指利用网络管理控制和技术措施&#xff0c;保…

Spark SQL中的from_json函数详解

Spark SQL中的from_json函数详解 在Spark SQL中&#xff0c;from_json是一个用于解析JSON数据的函数&#xff0c;主要用于将JSON格式的字符串解析为结构化的数据&#xff08;即StructType或其他Spark SQL数据类型&#xff09;。这个函数在处理半结构化数据&#xff08;如JSON日…

wsl 使用 docker

直接在 wsl 安装 docker , 有可能会失败&#xff0c;可以通过在 windows 安装 Docker Desktop&#xff0c;然后连接 wsl 进行解决 注意&#xff1a; 1. 需要先安装 wsl 2. 使用时要先启动 docker Desktop, 才能在 wsl 中使用 下载&#xff1a; Docker: Accelerated Containe…

海康威视摄像头RTSP使用nginx推流到服务器直播教程

思路&#xff1a; 之前2020年在本科的时候&#xff0c;由于项目的需求需要将海康威视的摄像头使用推流服务器到网页进行直播。这里将自己半个月琢磨出来的步骤给大家发一些。切勿转载&#xff01;&#xff01;&#xff01;&#xff01; 使用网络摄像头中的rtsp协议---------通…

CentOS 7.9下安装Docker

一、安装docker前的准备工作 操作系统版本为centos 7.9&#xff0c;内核版本需要在3.10以上&#xff0c;需要保障能够连通互联网&#xff0c;为了避免安装过程中出现网络异常建议关闭linux的防火墙&#xff08;生产环境下不要关闭防火墙&#xff0c;可根据实际情况设置防火墙出…

路由器旁挂三层网络实现SDWAN互联(爱快SD-WAN)

近期因公司新办公区建设&#xff0c;原有的爱快路由器的SDWAN功能实现分支之间互联的服务还需要继续使用。在原有的小型网络中&#xff0c;使用的爱快路由器当作网关设备&#xff0c;所以使用较为简单,如下图所示。 现变更网络拓扑为三层网络架构&#xff0c;但原有的SDWAN分支…

LabVIEW 蔬菜精密播种监测系统

在当前蔬菜播种工作中&#xff0c;存在着诸多问题。一方面&#xff0c;播种精度难以达到现代农业的高标准要求&#xff0c;导致种子分布不均&#xff0c;影响作物的生长发育和最终产量&#xff1b;另一方面&#xff0c;对于小粒径种子&#xff0c;传统的监测手段难以实现有效监…