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

wordpress导入网站文章杭州龙席网络seo

wordpress导入网站文章,杭州龙席网络seo,上海永灿网站建设,wordpress 搜索词一、题目描述 给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。 叶子节点 是指没有子节点的节点。 示例 1: 输入:root [5,4,8,11,null,13,4,7,2,null,null,5,1], target…

一、题目描述

给你二叉树的根节点 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

二、解题思路

这个问题可以通过递归的方式解决。我们定义一个递归函数,该函数接受当前节点和当前路径和作为参数。递归函数的工作流程如下:

1. 如果当前节点是空,返回一个空列表。

2. 如果当前节点是叶子节点(即没有子节点),检查当前路径和是否等于目标值。如果是,将当前路径和加入到结果列表中。

3. 如果当前节点不是叶子节点,递归地调用函数:

  • 调用函数,参数是当前节点的左子节点和当前路径和加上当前节点的值。
  • 调用函数,参数是当前节点的右子节点和当前路径和加上当前节点的值。

4. 将两个递归调用中的结果合并到一起,并返回。

三、具体代码

class Solution {public List<List<Integer>> pathSum(TreeNode root, int targetSum) {List<List<Integer>> result = new ArrayList<>();if (root == null) {return result;}pathSum(root, targetSum, new ArrayList<>(), result);return result;}private void pathSum(TreeNode node, int target, List<Integer> currentPath, List<List<Integer>> result) {if (node == null) {return;}currentPath.add(node.val);if (node.left == null && node.right == null && target == node.val) {result.add(new ArrayList<>(currentPath));}pathSum(node.left, target - node.val, currentPath, result);pathSum(node.right, target - node.val, currentPath, result);currentPath.remove(currentPath.size() - 1);}
}

四、时间复杂度和空间复杂度

1. 时间复杂度
  • 递归函数调用次数:对于每个节点,我们最多会调用一次 pathSum 函数。因此,对于一个有 n 个节点的树,最坏情况下,函数会被调用 n 次。

  • 单次递归调用的时间复杂度:对于每个节点的单次递归调用,我们需要执行常数时间操作,如判断当前节点是否为空、更新当前路径、判断是否为叶子节点以及添加结果等。

  • 综上所述,总的时间复杂度是 O(n),其中 n 是树中节点的数量。
2. 空间复杂度
  • 递归调用栈:递归调用会使用系统栈来存储每一层递归的信息。在最坏的情况下,树可能是一个完全二叉树,此时递归调用栈的深度为 O(h),其中 h 是树的高度。

  • 其他空间:除了递归调用栈之外,我们不需要额外的空间来存储节点的信息,因此这部分的空间复杂度是 O(1)。

  • 综上所述,总的空间复杂度是 O(h),在最坏情况下是 O(n)。

五、总结知识点

  1. 递归函数pathSum 函数是一个递归函数,它接受当前节点、目标和当前路径作为参数,并递归地检查左子树和右子树。

  2. 二叉树的遍历:通过递归的方式,代码实现了对二叉树的遍历,从根节点开始,逐层向下,直到到达叶子节点。

  3. 路径和的概念:代码中维护了一个变量 currentPath,用于跟踪从根节点到当前节点的路径上所有节点值之和。

  4. 叶子节点的判断:通过检查当前节点的左右子节点是否都为空来确定一个节点是否是叶子节点。

  5. 条件语句:代码中使用了 if 条件语句来判断节点是否为空、是否为叶子节点以及路径和是否等于目标值。

  6. 递归终止条件:递归函数在遇到空节点时返回,这是递归的终止条件。

  7. 逻辑运算符:代码中使用了逻辑运算符 || 来组合两个递归调用,如果任意一个调用返回 true,则整个表达式返回 true。

  8. 函数的封装pathSum 函数被定义为 private,这意味着它只能在同一个类中被访问,这是封装的一种形式。

  9. 树的表示:代码中使用了 TreeNode 类来定义二叉树的节点,这是二叉树数据结构的基本表示方法。

  10. 列表的使用:代码中使用了 ArrayList 类来存储路径和结果,这是一种动态数组,可以方便地添加和删除元素。

以上就是解决这个问题的详细步骤,希望能够为各位提供启发和帮助。

http://www.hkea.cn/news/476513/

相关文章:

  • 网站开发合同协议百度百科推广费用
  • 推荐黄的网站产品推广策划
  • 济南网站建设设计公司线上运营推广
  • 小清新 wordpressseo排名是什么意思
  • 从客户—管理者为某一公司做一份电子商务网站管理与维护的方案自媒体是如何赚钱的
  • 黑龙江住房和城乡建设厅网站首页每日精选12条新闻
  • 做网站工作都包括什么企业网站搭建
  • 自己可以进行网站建设吗河北网站推广
  • 网站建设与管理论文seo整站怎么优化
  • 西安做网站收费价格网站流量监控
  • 福州网站制作有限公司南京疫情最新情况
  • 国外品牌设计网站天津疫情最新消息
  • 宁波有做网站的地方吗seo报价单
  • 深圳企业网站开发中国法律服务网app最新下载
  • 大连企业网站建站国外域名注册网站
  • 站长工具seo综合查询权重百度在线搜索
  • 伊犁网站建设评价怎样才能上百度
  • 房地产网站建设方案百度实名认证
  • 做外贸可以在哪些网站注册网络项目免费的资源网
  • 中国建设银行信用卡网站首页青岛关键词优化平台
  • 阿里云网站建设考试题目长沙网站推广服务公司
  • 甘肃建设项目审批权限网站俄罗斯搜索引擎yandex官网入口
  • 网站建设公司新员工培训ppt模板百度热门搜索排行榜
  • 仿魔客吧网站模板网址大全是ie浏览器吗
  • 网站产品后台界面怎么做湖南关键词排名推广
  • 网站数据每隔几秒切换怎么做的湖南百度seo排名点击软件
  • 网站制作先学什么百度新闻下载安装
  • 河南省网站建设哪家好免费观看行情软件网站进入
  • 粘合剂东莞网站建设体育热点新闻
  • 百度网站排名关键词整站优化培训网站建设