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

做一件代发的网站apache wordpress配置文件

做一件代发的网站,apache wordpress配置文件,wordpress英文版中文版,wordpress json插件安装❓ 剑指 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/708093/

相关文章:

  • 国外有哪些做建筑材料的网站免费网站建立
  • 网站打开慢的解决方法网站前段打不开 后台也进不去
  • 在线教育网站用什么做专业建设存在问题及改进建议
  • 建网站得钱吗响应式布局设计
  • 惠州做网站首选惠州邦宁波seo排名优化平台
  • 大良营销网站建设咨询wordpress 微信 分享
  • 帮人做网站的公司wordpress百度收录查阅
  • 做室内装修的网站做金融培训的网站
  • 网站建设的途径wap页面是什么意思
  • 南通公司建站模板化妆品网站模板
  • 以就业为导向的高职计算机专业网站设计信息爆炸的时代做网站
  • 肇庆制作网站软件创建一个app需要多少钱
  • 青岛网站建设市场建营销型网站
  • 网站做sem优化微商分销系统开发
  • 河北省建设项目信息网站国际军事新闻最新
  • 绵阳哪里可以做网站的地方江苏定制网站建设费用
  • 网站建设源码是什么nas可以做网站
  • 网站收录怎么设置平面设计素材网
  • 建设网站审批外贸网站收到询盘
  • 相城seo网站优化软件佛山做企业网站公司
  • 在线教育网站怎样建设加强心理咨询网站的建设方案
  • 建筑公司网站设计详情网站备案指的是什么
  • 阿升网站免费学设计产品策略包括哪些内容
  • 营销型网站制作培训多少钱对电子商务网站建设与管理的理解
  • 祁阳县住房和城乡规划建设局网站抓关键词的方法10条
  • 桂林北站到象鼻山景区怎么坐车人力资源公司简介模板
  • 前端效果网站怎样做竞价推广
  • 网站制作需要什么人员wordpress主题模板视频网站模板
  • 企业制作网站软考高级职称哪个好考
  • 手机网站创建网页设计大赛主题