当前位置: 首页 > news >正文

设计网站欣赏wordpress会员无法注册

设计网站欣赏,wordpress会员无法注册,wordpress新闻轮播制作,广东如何进行网站制作排名1题目 给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径,这条路径上所有节点值相加等于目标和 targetSum 。如果存在,返回 true ;否则,返回 false 。 叶子节点 是指没有…

1题目

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

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

示例 1:

输入:root = [5,4,8,11,null,13,4,7,2,null,null,null,1], targetSum = 22
输出:true
解释:等于目标和的根节点到叶节点路径如上图所示。
示例 2:

输入:root = [1,2,3], targetSum = 5
输出:false
解释:树中存在两条根节点到叶子节点的路径:
(1 --> 2): 和为 3
(1 --> 3): 和为 4
不存在 sum = 5 的根节点到叶子节点的路径。
示例 3:

输入:root = [], targetSum = 0
输出:false
解释:由于树是空的,所以不存在根节点到叶子节点的路径。

2链接

题目链接:112. 路径总和 - 力扣(LeetCode)

视频链接:拿不准的遍历顺序,搞不清的回溯过程,我太难了! | LeetCode:112. 路径总和_哔哩哔哩_bilibili

3解题思路

本题适合递归法,可以使用深度优先遍历的方式(本题前中后序都可以,无所谓,因为中节点也没有处理逻辑)来遍历二叉树

1、确定递归函数的参数和返回类型

参数:需要二叉树的根节点,还需要一个计数器,这个计数器用来计算二叉树的一条边之和是否正好是目标和,计数器为int型。

再来看返回值,递归函数什么时候需要返回值?什么时候不需要返回值?这里卡哥总结如下三点:

a. 如果需要搜索整棵二叉树且不用处理递归返回值,递归函数就不要返回值。

b. 如果需要搜索整棵二叉树且需要处理递归返回值,递归函数就需要返回值。 

c. 如果要搜索其中一条符合条件的路径,那么递归一定需要返回值,因为遇到符合条件的路径了就要及时返回。

而本题我们要找一条符合条件的路径,所以递归函数需要返回值,及时返回,那么返回类型是什么呢?

如图所示:

图中可以看出,遍历的路线,并不要遍历整棵树,所以递归函数需要返回值,可以用bool类型表示。 

2、确定终止条件

计数器如何统计这一条路径的和?

不要去累加然后判断是否等于目标和,那么代码比较麻烦,可以用递减,让计数器count初始为目标和,然后每次减去遍历路径节点上的数值。

如果最后count == 0,同时到了叶子节点的话,说明找到了目标和。

如果遍历到了叶子节点,count不为0,就是没找到。

递归终止条件代码如下:

3、确定单层递归的逻辑

因为终止条件是判断叶子节点,所以递归的过程中就不要让空节点进入递归了。

递归函数是有返回值的,如果递归函数返回true,说明找到了合适的路径,应该立刻返回。

4代码

/*** 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 traversal(TreeNode* node, int target) {//遇到叶子结点,且目标值被减为零,说明符合题意,返回True否则falseif (node->left == nullptr && node->right == nullptr && target == 0) return true;if (node->left == nullptr && node->right == nullptr && target != 0) return false;if (node->left) { //左子树target -= node->left->val; //目标值每访问一个节点就减去其值//说明在递归的过程中找到了目标路线,一层层返回上来tureif (traversal(node->left, target)) return true;target += node->left->val;//回溯,目的为了还原目标值,去遍历右子树}if (node->right) {//右子树,下面同理target -= node->right->val;if (traversal(node->right, target)) return true;target += node->right->val;}return false;//以上都没返回true说明没找到,那就返回false}bool hasPathSum(TreeNode* root, int targetSum) {if (root == nullptr) return false;//空节点return(traversal(root, targetSum - root->val));//调用递归函数}
};

一定要看懂上面的二叉树回溯图,和这个代码对应极其密切

http://www.yayakq.cn/news/460199/

相关文章:

  • 网站引导页一般是什么格式二建证考试需要什么条件
  • 苏州营销型网站推广计划有几种状态
  • 电子公司网站源码建设一个网站的需求分析
  • 怎么用vs2010做网站设计wordpress导入数据库结构
  • 个人养老保险账户余额查询洛阳400电话洛阳网站seo
  • 注册外贸网站有哪些问题wordpress分类推荐
  • 郑州网站建设的软件巫溪集团网站建设
  • 响应式网站建设教程网站开发学什么比较有优势
  • 怎么弄自己的域名长沙网站seo技术
  • 做织梦网站的心得体会wordpress搬家菜单
  • 网站数据建设涉及哪些内容outlook企业邮箱收费标准
  • 安福县住房和城乡建设局网站百度爱采购推广效果怎么样?
  • 天网网站建设京东怎么开店
  • 星凯网站建设中信建设网站
  • 设计网站推荐提升审美把公司建设成全国一流企业
  • 微网站怎样做微信公众号做电影网站
  • 诱导网站怎么做省级门户网站建设
  • 极速网站建设服务商个人网站名称有哪些
  • 58招聘网站官网红酒 专业 网站建设
  • 国外的网站可以做百度推广吗绵阳做网站
  • 网站做的长图能导出吗模板之家怎么免费下载
  • 制作一个网站需要多少钱10m光纤做网站
  • 郑州网站推广怎么做wordpress分类汉字转拼音
  • 廊坊建设网站公司易贝跨境电商平台
  • 做艺术品的网站有哪些html网页制作app下载
  • 怎么仿网站链接天津怎么建立企业网站
  • 阿里巴巴国际站怎么做网站模版wordpress按作者归档
  • 网站建设内部需求调查表如何建立本站站点
  • 网站跳转qq链接怎么做的外网如何访问群晖wordpress
  • 一般网站建设用什么语言先做网站还是先备案