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

信息流广告二级代理上海百度搜索优化

信息流广告二级代理,上海百度搜索优化,房产网上备案查询,自媒体平台收益❓ 剑指 Offer 34. 二叉树中和为某一值的路径 难度:中等 给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。 叶子节点 是指没有子节点的节点。 示例 1: 输入&#xff1a…

❓ 剑指 Offer 34. 二叉树中和为某一值的路径

难度:中等

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

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

示例 1:

在这里插入图片描述

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

示例 2:

在这里插入图片描述

输入:root = [1,2,3], targetSum = 5
输出:[]

示例 3:

输入:root = [1,2], targetSum = 0
输出:[]

提示

  • 树中节点总数在范围 [0, 5000]
  • -1000 <= Node.val <= 1000
  • -1000 <= targetSum <= 1000

注意:本题与 113. 路径总和 II 相同。

💡思路:dfs

深度优先搜索的方式,枚举每一条从根节点到叶子节点的路径。

  • 当我们遍历到叶子节点,且此时路径和恰为目标和时,我们就找到了一条满足条件的路径,将 数组 tmp 加入 ans
  • 返回时,要删除当前数组 tmp 最后一个元素。

🍁代码:(C++、Java)

C++

/*** 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 {
private:vector<vector<int>> ans;void path(TreeNode* root, vector<int>& tmp, int sum){if(root == nullptr) return;sum -= root->val;tmp.push_back(root->val);if(sum == 0 && root->left == nullptr && root->right == nullptr) {ans.push_back(tmp);}else{path(root->left, tmp, sum);path(root->right, tmp, sum);}tmp.pop_back();return;}
public:vector<vector<int>> pathSum(TreeNode* root, int target) {vector<int> tmp;path(root, tmp, target);return ans;}
};

Java

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {private List<List<Integer>> ans = new LinkedList<List<Integer>>();private void path(TreeNode root, List<Integer> tmp, int sum){if(root == null) return;sum -= root.val;tmp.add(root.val);if(sum == 0 && root.left == null && root.right == null) {ans.add(new LinkedList(tmp));}else{path(root.left, tmp, sum);path(root.right, tmp, sum);}tmp.remove(tmp.size() - 1);return;}public List<List<Integer>> pathSum(TreeNode root, int target) {List<Integer> tmp = new LinkedList<>();path(root, tmp, target);return ans;}
}

🚀 运行结果:

在这里插入图片描述

🕔 复杂度分析:

  • 时间复杂度 O ( n 2 ) O(n^2) O(n2),其中 n 为树的节点数。在最坏情况下,树的上半部分为链状,下半部分为完全二叉树,并且从根节点到每一个叶子节点的路径都符合题目要求。此时,路径的数目为 O ( n ) O(n) O(n),并且每一条路径的节点个数也为 O ( n ) O(n) O(n),因此要将这些路径全部添加进答案中,时间复杂度为 O ( n 2 ) O(n^2) O(n2)
  • 空间复杂度 O ( n ) O(n) O(n),空间复杂度主要取决于栈空间的开销,栈中的元素个数不会超过树的节点数。

题目来源:力扣。

放弃一件事很容易,每天能坚持一件事一定很酷,一起每日一题吧!
关注我LeetCode主页 / CSDN—力扣专栏,每日更新!

注: 如有不足,欢迎指正!

http://www.qdjiajiao.com/news/7726.html

相关文章:

  • 我想创个网站百度推广竞价技巧
  • 奉贤广州网站建设中国重大新闻
  • 网站开发东莞关于网络推广的方法
  • 中铁建设集团有限公司官方网站免费网站制作平台
  • 有没有教做零食的网站做网页的网站
  • wordpress 独立 分类seo管理系统培训运营
  • 长沙建立网站平台推广计划
  • 公司网站推广怎么做网站分析工具
  • 目前做啥网站能致富湖南企业网站建设
  • 制作网站必做步骤seo排名方案
  • 厦门 做网站百度关键词流量查询
  • 用jsp做的动态网站想做网络推广如何去做
  • 什么网站容易做流量app推广拉新工作可靠吗
  • 小程序代理商怎么赚钱长春seo优化企业网络跃升
  • 太原提高网站排名培训网
  • 如何在office做网站佛山疫情最新消息
  • 企业手机网站建设方案nba最新交易
  • 郑州网站定制公司网络推广方法
  • 手机网站怎么上传图片疫情优化调整
  • 上海建设房屋网站西安网站托管
  • 百度云服务器建设网站如何做平台推广
  • 营销型网站建设哪家公司好baidu百度首页官网
  • 网址导航网站建站网站seo搜索引擎优化怎么做
  • 最好的企业网站seo是什么意思 为什么要做seo
  • php网站建设开发seo辅助工具
  • asp网站开发实例书籍浏览器2345网址导航下载安装
  • 青岛做网站报价百度推广代理公司哪家好
  • 台州做网站网络热词的利弊
  • 网页ui素材武汉网站seo推广
  • 网站页面布局设计建网站需要哪些步骤