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

在线做qq空间的网站吗百度一下百度网站

在线做qq空间的网站吗,百度一下百度网站,萍乡网站建设哪家好,wordpress 如何使用php版本号路径总和 I : 给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径,这条路径上所有节点值相加等于目标和 targetSum 。如果存在,返回 true ;否则,返回 false 。…

路径总和 I :

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

要点:判断是否存在满足条件的路径,只需返回true or false。

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

解题思路:

每遍历一个节点,就从targetsum中减去当前节点的值,当遍历到叶子节点时,如果targetsum=0,说明存在该路径,返回true。反之,返回false

class Solution {
public:bool hasPathSum(TreeNode* root, int targetSum) {if(root==nullptr) return false;targetSum-=root->val;if(root->left==nullptr&&root->right==nullptr){return targetSum==0;}//左子树和右子树有一个满足就可以,所以用||的关系return hasPathSum(root->left,targetSum)||hasPathSum(root->right,targetSum);}
};

 

路径总和 II:

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

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

要点:返回所有满足题意的路径,必须是从根节点开始,叶子节点结束。

 

输入:root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
输出:[[5,4,11,2],[5,8,4,5]]

解题思路:

 添加一个临时数组,用来存放当前遍历到的节点走过的路径。其他的与第一题相同,找到符合题意的路径,就将临时数组存放到结果数组中,若不符合条件,需回退,注意回退时需要将将一个放到临时数组中的节点删掉。

class Solution {
public:vector<vector<int>> res;//所有路径vector<int> temp;//当前路径void dfs(TreeNode* root, int targetSum){if(root==nullptr) return;temp.push_back(root->val);//当前节点放入到temp中targetSum-=root->val;//从总和中减去//若遇到叶子节点,需判断目标值是否已经为0if(root->left==nullptr&&root->right==nullptr){//目标值=0,说明当前路径符合题意,temp放到res中if(targetSum==0){res.push_back(temp);}}//递归dfs(root->left,targetSum);dfs(root->right,targetSum);//不符合题意,将当前节点从路径中删掉temp.pop_back();}vector<vector<int>> pathSum(TreeNode* root, int targetSum) {dfs(root,targetSum);return res;}
};

路径总和 III:

给定一个二叉树的根节点 root ,和一个整数 targetSum ,求该二叉树里节点值之和等于 targetSum路径 的数目。

路径 不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点)。

要点:返回的是所有符合题意的路径总条数,与第二题不一样的是,可以不是从根节点开始,也不需要在叶子节点结束。

输入:root = [10,5,-3,3,2,null,11,3,-2,null,1], targetSum = 8
输出:3
解释:和等于 8 的路径有 3 条,如图所示。 

解题思路:

相当于是递归套递归,构建一个找路径函数,遍历以当前节点为起始的路径中,是否存在符合题意的路径,然后再在原函数递归到每一个节点,使每一个节点都为起始节点进行找符合题意的路径。

class Solution {
public:int res=0;int pathSum(TreeNode* root, int targetSum) {if(root==nullptr) return res;find_path(root,targetSum);//以当前的root节点为起始节点,找路径pathSum(root->left,targetSum);//递归当前根节点的左子树上的节点pathSum(root->right,targetSum);//递归当前根节点的右子树上的节点return res;}//找路径函数void find_path(TreeNode* root,long targetSum){if(root==nullptr) return;targetSum -= root->val;if(targetSum==0)//只要targetsum=0,说明存在一条路径,那么res++{res+=1;}find_path(root->left,targetSum);find_path(root->right,targetSum);}
};
http://www.dt0577.cn/news/53620.html

相关文章:

  • 网站首页幻灯片尺寸导航网站怎么推广
  • 免费做请帖的网站广告软文
  • 网站前台功能模块设计seo专员工资一般多少
  • 泰安房产价格最新seol英文啥意思
  • 武义县网站建设网站建设免费网站
  • 常用的网站开发设计语言全国最大的关键词挖掘
  • 中国广告公司100强网络营销郑州优化推广公司
  • 网站建设的缺点百度在西安有分公司吗
  • 安装wordpress导入工具广州网站营销seo费用
  • 网站开发软件d如何制作一个自己的网页
  • 左右翻网站模版seo推广方案怎么做
  • 找人做设计的网站上海培训机构整顿
  • 石家庄h5网站建设搜易网托管模式的特点
  • 洛阳做网站公司哪家好seo日常工作内容
  • 织梦网站后台密码品牌公关
  • 装修公司加盟模式百度seo公司
  • 网站手机微信三合一怎么做泉州seo报价
  • 东营市住房和建设委员会网站百度推广费
  • 做运营需要知道素材网站百度竞价点击神器奔奔
  • 青岛的网站建设有没有免费的广告平台
  • xml网站地图格式网站网络推广运营
  • 东莞专业微网站建设简述网站推广的方法
  • 聚享游网站如何做推广湖南网站建站系统哪家好
  • 机械毕业设计代做网站网站推广途径和推广要点有哪些?
  • 广州响应式网站建设百度引擎入口
  • 株洲做网站优化友联互换
  • 怎么做网站二级页面抖音seo代理
  • 苏州网站建设万户seo网站整站优化
  • 网站建设中 模板怎么做信息流广告代理商
  • 郑州百度网站推广关键词免费