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

姐姐直播tv关键词优化的发展趋势

姐姐直播tv,关键词优化的发展趋势,wordpress页脚小工具导航,个人网站的建设参考文献题目: 给定一个二叉树的根结点root,和一个整数targetSum,求该二叉树力节点值之和等于targetSum的路径数目。 路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点) 方法一…

题目:

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

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


方法一:深度优先搜索

首先想到的解法是穷举所有的可能,访问每一个节点 node,检测以 node 为起始节点且向下延深的路径有多少种,递归遍历每一个节点的所有可能的路径,然后将这些路径数目加起来即为返回结果。

首先定义 rootSum(p,val) 表示以节点 p 为起点向下且满足路径总和为 val 的路径数目,对二叉树上每个节点 p 求出 rootSum(p,targetSum),然后对这些路径数目求和即为返回结果。

对节点 p 求 rootSum(p,targetSum) 时,以当前节点 p 为目标路径的起点递归向下进行搜索。假设当前的节点 p 的值为 val,对左子树和右子树进行递归搜索,对节点 p 的左孩子节点 pi求出rootSum(pl,targetSum-val).以l及对右孩子节点P求出rootSum(pr,targetSum-val),节点 p 的root(p.targetSum)即等于rootSum(pl,targetSum-val)与rootSum(pr,targetSum-val)之和同时我们还需要判断一下当前节点 p 的值是否刚好等于 targetSum

采用递归遍历二叉树的每个节点 p,对节点 p 求 rootSum(p,val),然后将每个节点所有求的值进行相加求和返回。

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution(object):def pathSum(self, root, targetSum):""":type root: Optional[TreeNode]:type targetSum: int:rtype: int"""def rootSum(root,targetSum):  #计算从当前 root 节点开始的路径数量if root is None:return 0ret=0  #初始化计数变量 ret,用于存储当前路径满足 targetSum 的数量if root.val==targetSum: #如果当前节点 root 的值等于 targetSumret+=1ret+=rootSum(root.left,targetSum-root.val)#递归计算左子树ret+=rootSum(root.right,targetSum-root.val)#递归计算右子树return retif root is None:return 0ret=rootSum(root,targetSum)#计算从 root 开始的路径数量ret+=self.pathSum(root.left,targetSum)#递归计算左子树的路径和,不一定非得从root开始ret+=self.pathSum(root.right,targetSum)#递归计算右子树的路径和,不一定非得从root开始return ret

时间复杂度:O(N2)N 为该二叉树节点的个数。对于每一个节点,求以该节点为起点的路径数目时,则需要遍历以该节点为根节点的子树的所有节点,因此求该路径所花费的最大时间为 O(N),我们会对每个节点都求一次以该节点为起点的路径数目,因此时间复杂度为 O(N2)


方法二:前缀和

定义节点的前缀和为:由根结点到当前结点的路径上所有节点的和,利用先序遍历二叉树,记录下根节点 root 到当前节点 p 的路径上除当前节点以外所有节点的前缀和,在已保存的路径前缀和中查找是否存在前缀和刚好等于当前节点到根节点的前缀和 curr 减去 targetSum

对于空路径我们也需要保存预先处理一下,此时因为空路径不经过任何节点,因此它的前缀和为 0

假设根节点为 root,我们当前刚好访问节点 node,则此时从根节点 root 到节点 node 的路径(无重复节点)刚好为 root→p1 →p2→…→pk​→node,此时我们可以已经保存了节点p1,p2 ,p3 ,…,p k的前缀和,并且计算出了节点 node 的前缀和

假设当前从根节点 root 到节点 node 的前缀和为 curr,则此时我们在已保存的前缀和查找是否存在前缀和刚好等于 curr−targetSum。

假设从根节点 root 到节点 node 的路径中存在节点 p i到根节点 root 的前缀和为 curr−targetSum则节点 p i+1​ 到 node 的路径上所有节点的和一定为 targetSum

利用深度搜索遍历树,当我们退出当前节点时,我们需要及时更新已经保存的前缀和

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = rightclass Solution(object):def pathSum(self, root, targetSum):""":type root: Optional[TreeNode]:type targetSum: int:rtype: int"""prefix=collections.defaultdict(int)  #创建具有默认值的字典,用于存储前缀和的计数
#当访问一个不存在的键时,它会默认返回 int() 的值,即 0prefix[0]=1  #表示 当前缀和为 0 时,有 1 种方法(即不选择任何节点)def dfs(root,curr):  #深度优先搜索(DFS)遍历二叉树,代表从根节点到当前节点的路径和if not root:return 0ret=0 #初始化 ret,用于存储当前路径中符合 targetSum 的路径数量curr+=root.val #累加当前节点值 root.val,得到当前路径和ret+=prefix[curr-targetSum]#计算当前前缀和 curr 与 targetSum 的差值prefix[curr]+=1 #更新 prefix 哈希表,增加当前路径和 curr 的出现次数ret+=dfs(root.left,curr) #递归计算左子树的路径数目ret+=dfs(root.right,curr)#递归计算右子树的路径数目prefix[curr]-=1 #prefix[curr]仅用于当前DFS路径,所以要在返回上一层时减去当前值return retreturn dfs(root,0)#调用 dfs(root, 0),从 root 节点开始遍历,初始路径和 curr 设为 0

时间复杂度:O(N)

空间复杂度:O(N)

源自力扣官方题解
 

http://www.dtcms.com/wzjs/516152.html

相关文章:

  • 梅山建设局网站免费网站建站页面
  • 网站建设公司的性质一站式自媒体服务平台
  • 软件技术有限公司搜索引擎优化案例分析
  • 政府网站建设指引推广网络推广
  • 旅游网站建设的建议com域名多少钱一年
  • flash网站策划书河南网站公司
  • 网站怎么做能快速有排名seo教程技术资源
  • 公益建设网站的作用杭州网站seo外包
  • 广东哪家网站建设后台管理便捷抖音的商业营销手段
  • 桂林网站建设找骏程今天实时热搜榜排名
  • 做单页面网站2022最火营销方案
  • asp动态网站 是什么网站设计公司哪家专业
  • wordpress春菜优化seo网站
  • 做家政网站谷歌网站网址
  • 做哪个视频网站赚钱bt磁力
  • 织梦网站模板如何安装教程视频网站点击量与排名
  • 国资委网站建设网页制作软件哪个好
  • 公司制作一个网站价格最新新闻热点大事件
  • 网站建设怎么建设百度ai助手入口
  • 网站建设电销话术汕头网站建设公司哪个好
  • 什么是跨境电商平台潍坊seo计费
  • 网站的评测系统怎么做的上海百度竞价点击软件
  • 网页设计欣赏熊出没seo交流中心
  • 什么是经营性网站备案seort什么意思
  • 网站备案人的法律风险平台外宣推广技巧
  • 济南网站制作价格怎么从网上找国外客户
  • 怎么做影视网站cpm广告联盟平台
  • 佛山专注网站制作细节长春最专业的seo公司
  • 南充网站建设服务商如何快速搭建一个网站
  • 用dw做动态网站的步骤互联网广告平台排名