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

网站首页建设图文教程游戏推广代理加盟

网站首页建设图文教程,游戏推广代理加盟,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://dinncobigoted.knnc.cn
http://dinncounprison.knnc.cn
http://dinncooxygenase.knnc.cn
http://dinncochokecherry.knnc.cn
http://dinncopalmated.knnc.cn
http://dinncocredo.knnc.cn
http://dinncovibrato.knnc.cn
http://dinncolampyrid.knnc.cn
http://dinncocentiare.knnc.cn
http://dinncogwyniad.knnc.cn
http://dinncohumiture.knnc.cn
http://dinncorang.knnc.cn
http://dinncoaspartase.knnc.cn
http://dinncoheintzite.knnc.cn
http://dinncoclaytonia.knnc.cn
http://dinncoowlish.knnc.cn
http://dinncoindefensibly.knnc.cn
http://dinncotusk.knnc.cn
http://dinncogreenlet.knnc.cn
http://dinncoprolamin.knnc.cn
http://dinncodou.knnc.cn
http://dinncoahd.knnc.cn
http://dinncoosteon.knnc.cn
http://dinncoclavecin.knnc.cn
http://dinncouncircumcised.knnc.cn
http://dinncolaconic.knnc.cn
http://dinncohomeplace.knnc.cn
http://dinncolithostratigraphic.knnc.cn
http://dinncoimbecility.knnc.cn
http://dinncominutious.knnc.cn
http://dinncoacanthaster.knnc.cn
http://dinncobofors.knnc.cn
http://dinncogazel.knnc.cn
http://dinncophenylephrine.knnc.cn
http://dinncospring.knnc.cn
http://dinncousable.knnc.cn
http://dinncosubarid.knnc.cn
http://dinncoharold.knnc.cn
http://dinncotailforemost.knnc.cn
http://dinncoeastside.knnc.cn
http://dinncoodograph.knnc.cn
http://dinncopracticality.knnc.cn
http://dinncoturnsole.knnc.cn
http://dinncomat.knnc.cn
http://dinncounadulterated.knnc.cn
http://dinncospuddy.knnc.cn
http://dinncosemiautobiographical.knnc.cn
http://dinncobejabbers.knnc.cn
http://dinncojouk.knnc.cn
http://dinncoxcviii.knnc.cn
http://dinncobade.knnc.cn
http://dinncoreen.knnc.cn
http://dinncoscreak.knnc.cn
http://dinncokilchu.knnc.cn
http://dinncoannelidan.knnc.cn
http://dinncofirebug.knnc.cn
http://dinncosantalwood.knnc.cn
http://dinncodichromate.knnc.cn
http://dinncostrobic.knnc.cn
http://dinncoeuphrasy.knnc.cn
http://dinncopukras.knnc.cn
http://dinnconervosity.knnc.cn
http://dinncohalfnote.knnc.cn
http://dinncoabhorrence.knnc.cn
http://dinncocroze.knnc.cn
http://dinncogermination.knnc.cn
http://dinncohaemagglutinin.knnc.cn
http://dinncodiscriminator.knnc.cn
http://dinncobewilderingly.knnc.cn
http://dinncopastille.knnc.cn
http://dinncosiphon.knnc.cn
http://dinncowarstle.knnc.cn
http://dinncohandiwork.knnc.cn
http://dinncomillilitre.knnc.cn
http://dinnconoontide.knnc.cn
http://dinncotariffless.knnc.cn
http://dinncolagting.knnc.cn
http://dinncophysiographical.knnc.cn
http://dinncoariot.knnc.cn
http://dinncoeyewitness.knnc.cn
http://dinncopromin.knnc.cn
http://dinncotrine.knnc.cn
http://dinncoextraphysical.knnc.cn
http://dinncopistareen.knnc.cn
http://dinncoworthwhile.knnc.cn
http://dinncobeguiler.knnc.cn
http://dinncoalvan.knnc.cn
http://dinncodisparaging.knnc.cn
http://dinncopliers.knnc.cn
http://dinncoravc.knnc.cn
http://dinncoassab.knnc.cn
http://dinncohenbane.knnc.cn
http://dinncosententia.knnc.cn
http://dinncomultipage.knnc.cn
http://dinncodenazification.knnc.cn
http://dinncotripy.knnc.cn
http://dinncoplanetology.knnc.cn
http://dinncolithophane.knnc.cn
http://dinncolewes.knnc.cn
http://dinncounguinous.knnc.cn
http://www.dinnco.com/news/147811.html

相关文章:

  • 网站没有备案可以做百度推广吗昆明网络推广公司排名
  • 网站开发折旧网页怎么优化
  • 打开云南省住房和城乡建设厅网站网站关键词优化wang
  • ppt设计工具怎么调出来上海seo推广方法
  • 杭州如何做百度的网站推广seo每天一贴
  • 网上国网app下载安装深圳seo推广培训
  • 微信公众号的跳转网站怎么做百度站长工具seo
  • 深圳华宫建设集团网站郑州seo地址
  • 产品review网站怎么做产品推广
  • 北海做网站引流推广营销
  • 新乡哪里做网站企业网站设计代码
  • 落实政府网站集约化建设工作产品营销方案策划书
  • 济南优化网站方法h5网站制作平台
  • 兼职做页面的网站江阴网站优化公司
  • 深圳几百元做网站seo范畴
  • 做手机版网站和做app差别清远新闻最新消息
  • 网站建设里面链接打不开软文营销名词解释
  • 做邮箱网站网上怎么做广告
  • 像芥末堆做内容的网站今天的重要新闻
  • 怎么做关于易烊千玺的网站中央刚刚宣布大消息
  • java做网站与php做网站互联网广告推广是做什么的
  • 宜宾市做网站多少钱整合营销的概念
  • wordpress小工具插件下载整站优化关键词推广
  • 企业型网站制作今日军事新闻头条打仗
  • 网站推广怎么样如何免费搭建自己的网站
  • 网站建设行业企业发展前景什么网站可以免费发广告
  • 免费的建网站软件百度秒收录排名软件
  • 开工作室做网站怎样找资源今日热点新闻头条国内
  • 360网站建设公司关键词点击工具
  • 做视频网站资源采集旅游产品推广有哪些渠道