力扣112、113、101--树

112. 路径总和

题目描述:

给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。
判断该树中是否存在 根节点到叶子节点 的路径,这条路径上所有节点值相加等于目标和 targetSum 。
如果存在,返回 true ;否则,返回 false 。叶子节点 是指没有子节点的节点

方法一:树考虑递归

1.终止条件:到叶子结点且值相等-->true;到叶子结点值不相等--->false;
2.递归关系式 :bool root_sum=bool left_sum1 || bool right_sum1
根到叶子的和是否为sum就是左孩子到叶子的和是否为sum—root或右孩子到叶子的和是否为sum—root

所以代码为:

class Solution {
public:bool hasPathSum(TreeNode* root, int targetSum) {if(!root) return false;if(!root->left && !root->right) return targetSum==root->val;return  hasPathSum(root->left, targetSum-root->val)|| hasPathSum(root->right, targetSum-root->val);}
};

方法二:DFS

class Solution {
public:bool hasPathSum(TreeNode* root, int targetSum) {if(!root) return false;return dfs(root,targetSum);}bool dfs(TreeNode* root, int Sum){if(!root) return false ;Sum-=root->val;if(Sum==0&&!root->left&&!root->right) return true;bool leftResult = dfs(root->left, Sum);bool rightResult = dfs(root->right, Sum);// 如果左子树或右子树存在满足条件的路径,返回trueif(leftResult || rightResult) {return true;}return false;}};

这里需要注意一下:在递归回溯时,我们不需要将当前节点的值再次加回到sum中。

理解方式:因为在后续调用dfs时sum是个参数,他只是把此时sum的值复制一份传递给下一层递归函数。这意味着后续调用的Sum值是独立的,不会影响到之前的调用

例如:

#include<stdio.h>
using namespace std;int add(int a,int b){return a=a+b;
}int main(){int a=0;int c=add(a,3);printf("%d",a);return 0;} 

113. 路径总和 II

给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。

这道题跟上道题的区别在于需要返回路径。其他大体思路差不多,可以直接dfs遍历。

class Solution {
public:vector<vector<int>> pathSum(TreeNode* root, int targetSum) {dfs(root,targetSum);return res;}
private:vector<vector<int>> res;vector<int> path;void dfs(TreeNode* root,int tar){if(!root) return ;path.push_back(root->val);//向下遍历tar-=root->val;if(tar==0&&!root->left&&!root->right){res.push_back(path);}//成功dfs(root->left,tar);//左dfs(root->right,tar);//右path.pop_back();//回溯}
};

注意这道题里面每次dfs后path需要pop因为path是全局变量 

101. 对称二叉树

注意:这道题不可以用中序遍历,会出现:这种情况

正确做法:左右都存在的情况下,递归的判断,L->right==R->left   R->right==L->left;?

class Solution {
public:bool isSymmetric(TreeNode* root) {if(!root) return true;return dfs(root->left,root->right); }bool dfs(TreeNode* L,TreeNode* R){if(!L&&!R) return true;if( !L||!R) return false;if(L->val!=R->val) return false;//member access within null pointer of type 'TreeNode' 不能比较空return dfs(L->right,R->left)&&dfs(R->right,L->left);}
};

199. 二叉树的右视图

给定一个二叉树的 根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。

方法一:横向思考:最右边的就是每一层的最右边的一个节点---》层次遍历,每次队列出完一行,一层到最后的时候,就是最右边的节点。

class Solution { // 层序遍历
public:vector<int> rightSideView(TreeNode* root) {vector<int> res;if (!root)return res;queue<TreeNode*> q;TreeNode* visit;q.push(root);while (!q.empty()) {int q_size = q.size();for (int i = 0; i < q_size; i++) {visit = q.front();q.pop();if (i == q_size - 1) {res.push_back(visit->val);}if (visit->left)q.push(visit->left);if (visit->right)q.push(visit->right);}}return res;}
};

每层结束的判断:

int q_size = q.size();
//确保每次上一层全部遍历完后,立马计算当前队列的大小
if (i == q_size - 1) {res.push_back(visit->val);}

方法二:纵向思维:

思路: 我们按照 「根结点 -> 右子树 -> 左子树」 的顺序访问,就可以保证每层都是最先访问最右边的节点的。每次新的一层,就将节点的值放入到数组中。

(与先序遍历 「根结点 -> 左子树 -> 右子树」 正好相反,先序遍历每层最先访问的是最左边的节点)

class Solution {
public:vector<int> res;void pre(TreeNode* root,int deep){if(!root) return ;if(deep==res.size()) res.push_back(root->val);deep++;if(root->right) pre(root->right,deep);if(root->left) pre(root->left,deep);}vector<int> rightSideView(TreeNode* root) {pre(root,0);return res;}
};

226. 翻转二叉树

给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。

​​​​​​​注意:

  1. 在交换左右子树节点值时,应该交换节点指针而不仅仅是节点值。因此,应该使用swap(root->left, root->right)来交换左右子树节点。
  2. 在处理节点的左右子树时,应该先递归地对左右子树进行翻转操作,然后再交换左右子树的位置。因此,在调用invertTree函数之前应该先判断左右子树是否为空。
class Solution {
public:TreeNode* invertTree(TreeNode* root) {if (!root) {return nullptr;}// 递归地翻转左右子树TreeNode* left = invertTree(root->left);TreeNode* right = invertTree(root->right);// 交换左右子树root->left = right;root->right = left;return root;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/749744.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

轻松搞定找不到vcomp140.dll无法继续执行程序的5种方法

在我们日常使用计算机的过程中&#xff0c;频繁且不可避免地会遭遇到各种类型的错误提示信息&#xff0c;这些错误信息往往会在关键时刻阻碍我们的操作进程。其中&#xff0c;有一个颇为常见的错误提示值得我们关注&#xff0c;那就是“vcomp140.dll丢失”。这个错误提示涉及到…

【计算机视觉】二、图像形成——实验:2D变换编辑(Pygame)

文章目录 一、向量和矩阵的基本运算二、几何基元和变换1、几何基元(Geometric Primitives)2、几何变换(Geometric Transformations)2D变换编辑器0. 程序简介环境说明程序流程 1. 各种变换平移变换旋转变换等比缩放变换缩放变换镜像变换剪切变换 2. 按钮按钮类创建按钮 3. Pygam…

Python中sys.stdin.readline()与input()的区别

Python中sys.stdin.readline()与input()的区别 文章目录 Python中sys.stdin.readline()与input()的区别1.概念上的区别2.使用上的区别2.1异常处理2.2可重定向输入2.3迭代读取2.4灵活性2.5两种循环读取方式 1.概念上的区别 在 Python 中&#xff0c;input() 和 sys.stdin 是用于…

更安全的C gets()和str* 以及fgets和strcspn的用法

#include <stdio.h>int main() {char *str;gets(str);puts(str);return(0); }可以说全是错误 首先char *str没有指向一个分配好的地址&#xff0c;就直接读入&#xff0c;危险 ps: 怎么理解char *str "Hello World" 是将一个存储在一个只读的数据段中字符串常…

c语言:一元二次方程(可能有复根)

一元二次方程&#xff08;可能有复根&#xff09; 任务描述 输入三个系数&#xff0c;求一元二次方程的解,要求输出所有可能的情况,包括复根。 输入格式: 三个实数a,b,c 输出格式: 按输出样例格式输出&#xff0c;注意输出顺序。 输入示例1 1 6 9输出示例1 x1x2-3.00000…

AI预测-一文解析AI预测数据工程

AI预测相关目录 AI预测流程&#xff0c;包括ETL、算法策略、算法模型、模型评估、可视化等相关内容 最好有基础的python算法预测经验 EEMD策略及踩坑VMD-CNN-LSTM时序预测对双向LSTM等模型添加自注意力机制K折叠交叉验证optuna超参数优化框架多任务学习-模型融合策略Transform…

《操作系统实践-基于Linux应用与内核编程》第10章-Linux综合应用

前言: 内容参考《操作系统实践-基于Linux应用与内核编程》一书的示例代码和教材内容&#xff0c;所做的读书笔记。本文记录再这里按照书中示例做一遍代码编程实践加深对操作系统的理解。 引用: 《操作系统实践-基于Linux应用与内核编程》 作者&#xff1a;房胜、李旭健、黄…

复现文件上传漏洞

一、搭建upload-labs环境 将下载好的upload-labs的压缩包&#xff0c;将此压缩包解压到WWW中&#xff0c;并将名称修改为upload&#xff0c;同时也要在upload文件中建立一个upload的文件。 然后在浏览器网址栏输入&#xff1a;127.0.0.1/upload进入靶场。 第一关 选择上传文件…

数字孪生-使用Unity构建能实时显示应力应变的孪生模型

Motivation - 采用Unity作为孪生技术栈的经历? 最开始想要利用Ansys的Twin Builder模块来进行数字孪生的开发&#xff0c;但是Ansys 的Twin Builder在部署的时候&#xff0c;需要license&#xff0c;要获得license所要花费的价格是难以接受的。 后来想要利用QTVTK的方式来进行…

C++/CLI学习笔记3(快速打通c++与c#相互调用的桥梁)

c/cli变量和操作符 3.1:什么是变里 变量是存储数据以便应用程序临时使用的内存位置&#xff0c;具有名称、类型和值。变量值在应用程序执行期间可能改变&#xff0c;变量名也是。变量使用前必须声明&#xff0c;即指定类型和提供名称。变量的类型决定了值的范围以及能执行的操…

MATLAB:拟合与插值

一、关于多项式的基本操作 若要求非线性方程的根&#xff0c;则采用fzero, fminbnd函数 二、多项式拟合 clc, clear x0:0.2:10; y0.25*x20*sin(x); plot(x,y,k.,MarkerSize,15) grid on; hold on [p1,s1,mu1]polyfit(x,y,3); %3阶多项式拟合 y1polyval(p1,x,s1,mu1); [p2,s…

2024.3.17 机器学习周报

引言 Abstract 文献阅读 1、题目 R-TRANSFORMER: RECURRENT NEURAL NETWORK ENHANCED TRANSFORMER 2、引言 递归神经网络长期以来一直是序列建模的主要选择。然而&#xff0c;它严重遭受两个问题&#xff1a;在捕获非常长期的依赖性和无法并行化的顺序计算过程中无能为力…

云服务器2核4G能支持多少人同时访问?拿本记上!

腾讯云轻量2核4G5M带宽服务器支持多少人在线访问&#xff1f;5M带宽下载速度峰值可达640KB/秒&#xff0c;阿腾云以搭建网站为例&#xff0c;假设优化后平均大小为60KB&#xff0c;则5M带宽可支撑10个用户同时在1秒内打开网站&#xff0c;并发数为10&#xff0c;经阿腾云测试&a…

[蓝桥杯练习题]确定字符串是否包含唯一字符/确定字符串是否是另一个的排列

确定字符串是否包含唯一字符 #include<bits/stdc.h> using namespace std; int main(){ios::sync_with_stdio(0);cin.tie(nullptr);cout.tie(nullptr);map<char,int>m;string s;cin>>s;for(int i0;i<s.size();i){if(isalpha(s[i]))s[i]tolower(s[i]);if(…

Websocket服务监听收发消息

目录 1.pom依赖坐标2.项目配置端口和项目包名2.创建处理器3.注册处理器4.前端页面 1.pom依赖坐标 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId></dependency>2.项目配…

如何使用“Docker registry创建本地仓库,在服务器之间进行文件push和pull”?

1.1、在服务器1&#xff0c;运行registry docker run -d -p 5000:5000 -v ${PWD}/registry:/var/lib/registry --restart always --name registry registry:2.7.11.2、编辑/etc/docker/daemon.json 文件&#xff0c; 192.168.xxx.xxx 换成你自己 registry 服务的地址 sudo na…

印度交易所股票行情数据API接口

1. 历史日线 # Restful API https://tsanghi.com/api/fin/stock/XNSE/daily?token{token}&ticker{ticker}默认返回全部历史数据&#xff0c;也可以使用参数start_date和end_date选择特定时间段。 更新时间&#xff1a;收盘后3~4小时。 更新周期&#xff1a;每天。 请求方式…

mysql用 法like concat()

对于mysql 的 like 而言&#xff0c;一般都要用 like concat() 组合&#xff0c;可以防止sql注入 所以用未注释掉的呢种方式会比较好&#xff0c;不推荐直接用like的方式 。 like concat(%/,#{datePath,jdbcTypeVARCHAR},/%) concat函数&#xff1a; 第…

下载程序到嵌入式开发板教程

一、设置共享目录 ubuntu与Window共同拥有的目录。 第一步&#xff1a;在Windows下创建一个文件夹share 第二部&#xff1a;点击虚拟机--->设置--->选项--->共享文件夹 进入共享目录的命令&#xff1a;cd/mnt/hgfs/share 二、C语言编译器 使用Linux平台下的gcc编…

MyBatis Plus(代码生成器)

一、安装 安装MyBatisPlus插件 二、配置 1、 在生成代码之前首先需要配置所要连接的数据库 下面所对应的分别是&#xff1a; 所要连接的数据库 数据库驱动 用户名 密码 2、 点击Other->Code Generator 开始配置所需选项