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

免费建购物网站可以免费网络推广网站

免费建购物网站,可以免费网络推广网站,有系统源码可以做网站吗,wordpress4.8主题下载题目 给你一棵根为 root 的二叉树,请你返回二叉树中好节点的数目。 「好节点」X 定义为:从根到该节点 X 所经过的节点中,没有任何节点的值大于 X 的值。 一、代码实现 func goodNodes(root *TreeNode) int {if root nil {return 0}return d…

题目

给你一棵根为 root 的二叉树,请你返回二叉树中好节点的数目。
「好节点」X 定义为:从根到该节点 X 所经过的节点中,没有任何节点的值大于 X 的值。

一、代码实现

func goodNodes(root *TreeNode) int {if root == nil {return 0}return dfs(root, root.Val)
}func dfs(node *TreeNode, maxVal int) int {if node == nil {return 0}count := 0if node.Val >= maxVal {count = 1maxVal = node.Val}count += dfs(node.Left, maxVal)count += dfs(node.Right, maxVal)return count
}

二、算法分析

1. 核心思路
  • 深度优先遍历:通过前序遍历访问每个节点,实时维护路径最大值
  • 贪心比较:当前节点值若大于等于路径最大值,则标记为好节点并更新最大值
  • 递归分治:将问题分解为左右子树的子问题,合并结果得到总数
2. 关键步骤
  1. 初始化最大值:以根节点值作为初始路径最大值
  2. 递归终止条件:空节点返回0
  3. 节点判断:比较当前节点值与路径最大值,更新计数器和最大值
  4. 递归分解:分别处理左右子树,传递更新后的最大值
3. 复杂度
指标说明
时间复杂度O(n)每个节点访问一次
空间复杂度O(h)h为树的高度(递归栈空间)

三、图解示例

以二叉树[3,1,4,3,null,1,5]为例:

        3/ \1   4/   / \3   1   5

递归过程

  1. 根节点3:路径最大3 → 好节点(计数1)
  2. 左子节点1:路径最大3 → 不计数
  3. 左子节点的左子3:路径最大3 → 好节点(计数+1)
  4. 右子节点4:路径最大4 → 好节点(计数+1)
  5. 右子节点的左子1:路径最大4 → 不计数
  6. 右子节点的右子5:路径最大5 → 好节点(计数+1)
    总计数:1 + 1 + 1 + 1 = 4

四、边界条件与扩展

1. 特殊场景验证
  • 单节点树:返回1
  • 递减序列:如5→4→3→2 → 返回4(每个节点都是好节点)
  • 负数值:如[-2,null,-3] → 返回1(仅根节点是好节点)
2. 多语言实现
class Solution:def goodNodes(self, root: TreeNode) -> int:def dfs(node, max_val):if not node: return 0count = 0if node.val >= max_val:count = 1max_val = node.valreturn count + dfs(node.left, max_val) + dfs(node.right, max_val)return dfs(root, root.val)
class Solution {public int goodNodes(TreeNode root) {return dfs(root, root.val);}private int dfs(TreeNode node, int maxVal) {if (node == null) return 0;int count = 0;if (node.val >= maxVal) {count = 1;maxVal = node.val;}return count + dfs(node.left, maxVal) + dfs(node.right, maxVal);}
}

五、总结与扩展

1. 核心创新点
  • 路径最大值传递:通过递归参数动态维护路径最大值
  • 高效计数机制:仅需单次遍历即可完成所有判断
  • 空间优化:利用递归栈替代显式栈结构
2. 扩展应用
  • 路径最大值统计:可扩展记录所有路径中的最大值分布
  • 节点标记存储:修改算法以存储所有好节点列表
  • 多条件筛选:结合其他条件(如最小值、奇偶性)扩展筛选逻辑
3. 工程优化方向
  • 迭代实现:用栈模拟递归过程避免栈溢出
  • 并行计算:对左右子树进行并发遍历
  • 缓存优化:对大规模数据预计算路径特征
http://www.dtcms.com/wzjs/200717.html

相关文章:

  • 服务器在国外的网站百度官网入口
  • 政府网站建设的整改措施服务器ip域名解析
  • 外贸网站建设公司服务网站建设服务商
  • 做网站要多长时间seo外链推广员
  • 龙华做网站的公司微信营销是什么
  • 做网站专用素材百度云官网入口
  • 泰安做网站建设的公司成都推广系统
  • 公司改名网站备案发布任务注册app推广的平台
  • 做关键词排名卖网站seo 推广服务
  • 营销网站的推广百度趋势搜索大数据
  • 佟年给韩商言做的网站整站优化价格
  • 如何制作假网页手机端关键词排名优化软件
  • 顺口大气三个子公司名字排名怎么优化快
  • 遂宁建设网站网络推广外包怎么接单
  • 网站制作经典案例b2b十大平台排名
  • 城市建设理论研究官方网站网络营销渠道类型有哪些
  • 网站系统建设方案查权重工具
  • 网站建设设计方案百度网站大全
  • asp.net做的网站文字控件随窗口大小不变化优化营商环境
  • 微网站界面设计营销型网站的特点
  • 微商官网台州seo网站排名优化
  • 鲜花店的网站建设安卓优化大师官网
  • 需求网站建设打开百度网址
  • 有些公司做网站比较好的公司策划推广
  • 如何做简单的网站手游推广平台
  • 怎么做免费的企业网站有没有免费的crm系统软件
  • wordpress 升级https东莞百度seo新网站快速排名
  • 一流的做pc端网站中国网络营销公司
  • dz论坛网站源码百度查询关键词排名工具
  • 佛山网站制作网址赚钱平台