力扣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…

更安全的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" 是将一个存储在一个只读的数据段中字符串常…

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的方式来进行…

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(…

如何使用“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;每天。 请求方式…

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

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

MyBatis Plus(代码生成器)

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

【NR 定位】3GPP NR Positioning 5G定位标准解读(十四)-DL-TDOA 定位

前言 3GPP NR Positioning 5G定位标准&#xff1a;3GPP TS 38.305 V18 3GPP 标准网址&#xff1a;Directory Listing /ftp/ 【NR 定位】3GPP NR Positioning 5G定位标准解读&#xff08;一&#xff09;-CSDN博客 【NR 定位】3GPP NR Positioning 5G定位标准解读&#xff08;…

基于卷积神经网络实现手写数字识别

基于卷积神经网络实现手写数字识别 基于卷积神经网络实现手写数字识别。具体过程如下&#xff1a; &#xff08;1&#xff09; 定义ConvNet结构类及其前向传播方式 &#xff08;2&#xff09; 设置超参数以及导入相关的包。 &#xff08;3&#xff09; 定义训练网络函数和绘…

桌面待办,电脑桌面待办事项便利贴怎么搞的

电脑桌面待办事项贴便利&#xff0c;是一款非常实用的小工具&#xff0c;可以帮助我们高效管理工作和生活中的各种任务。通过简单的操作&#xff0c;你可以在电脑桌面上添加待办事项&#xff0c;随时提醒自己完成任务&#xff0c;提高工作效率。那么&#xff0c;桌面待办&#…

Hack The Box-Jab

目录 信息收集 nmap enum4linux 服务信息收集 Pidgin kerbrute hashcat 反弹shell & get user 提权 系统信息收集 端口转发 漏洞利用 get root 信息收集 nmap 端口探测┌──(root㉿ru)-[~/kali/hackthebox] └─# nmap -p- 10.10.11.4 --min-rate 10000 -oA…

vitepress里使用gitalk(图文教程)

vitepress里使用gitalk Gitalk 是一个基于 GitHub Issue 和 Preact 开发的评论插件 生成client配置 创建OAuth application 填写完毕&#xff0c;点击 Register application 即可 生成client secrets 一开始没有自动生成 Client secrets&#xff0c;需要手动生成&#xff…