当前位置: 首页 > 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.yayakq.cn/news/761945/

相关文章:

  • 一下成都网站建设公司软件开发培训机构去哪个学校
  • 网页设计与网站开发方向网站搭建费用价格表
  • 外贸网站建设哪家强标准网站建设的价格
  • asp网站防注入网站开发待遇好吗
  • 做网站需要流程wordpress能做出
  • html网站怎么做视频教程邯郸网站建设费用
  • 酒泉建设局网站网站建站平台 开源
  • 阿里巴巴可以做公司网站吗wordpress洛米主题
  • 关于我们 网站兰州网站建设哪里好
  • 老榕树建站软件揭阳网站推广教程
  • 四川省乐山市建设银行网站南宁关键词自然排名
  • 大连推广网站搭建哪家好wordpress菜单导航
  • 学校网站制作公司大连建设工程信息网查询
  • 网页制作与网站开发模板网页兼容性站点
  • 电商平台网站建设多少钱谢晶晶的赣州没有网页制作
  • html旅游网站模板如何做高校的网站版面设计
  • 对电子政务做技术支持的网站网站的建设模式
  • 想学做网站要去哪里学头像制作logo免费生成器在线
  • 可视化的做网站的app园林景观网站源码
  • wordpress layer怀柔网站整站优化公司
  • 站长工具域名解析抖音代运营有效果吗
  • 手机网站源码教程怎么样建立自己的网页
  • 网站开发市场调查网络建站
  • 没有防盗链的网站网易企业邮箱登陆入口官网
  • 网站搭建平台源码软文推广产品
  • 建设银行官网站下载网站制作什么做
  • 门窗 东莞网站建设淄博人力资源管理系统入口
  • 给别人做网站挣钱么销售平台有哪些电商
  • 泉州网页网站制作怎么在word上做超链接网站
  • 中企动力员工薪资福利常熟seo关键词优化公司