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

网站建设需要注意那些点百度seo关键词优化电话

网站建设需要注意那些点,百度seo关键词优化电话,营销网络是什么意思,做网站客户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.ds6.com.cn/news/34341.html

相关文章:

  • 北京做网站的好公司seo咨询
  • 福建省新特建设工程有限公司网站百度搜索指数的数据来源
  • 做图软件下载官方网站哈尔滨优化网站方法
  • 自己做网站系统首选平台网站服务器ip地址查询
  • 网站建设实验报告百度seo优化推广公司
  • 护士公共课在哪个网站做软文营销的三个层面
  • 网站网页设计方案广州:推动优化防控措施落地
  • 制作网站的公司注册资本要多少北京关键词排名推广
  • 创建一个网站主页流量精灵网页版
  • asp.net mvc6电商网站开发实践谷歌海外广告投放
  • 巩义网站建设方案报价进入百度app查看
  • 澳门wap网站制作营销网站模板
  • 我是做装修的怎么样投资网站免费建设网站平台
  • 114网站做推广怎么样品牌网站建设
  • 做网站优化如何写方案百度公司在哪里
  • 国家信用信息公示网查询官网seo全网营销公司
  • 网站怎么做图片滚动条seo优化排名营销
  • 网站建设需要会什么软件有哪些方面seo优化是什么意思
  • 深圳华强北赛格大厦关键词优化平台有哪些
  • 适合个人网站的名称优化推广网站怎么做
  • 店面门面设计南昌seo推广公司
  • wordpress使用密码夜狼seo
  • 分销系统合法吗网站运营seo实训总结
  • 亚马逊做网站发礼物换评价网址之家大全
  • 上不了国外网站 怎么做贸易精准的搜索引擎优化
  • 找人做网站昆明外包公司的人好跳槽吗
  • 汉口江岸区城市建设局网站宁波优化seo软件公司
  • 公众号网站怎么做东莞网站公司排名
  • 青岛 外语网站建设seo sem什么意思
  • seo 公司惠州seo计费管理