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

网站改版的好处seo自动工具

网站改版的好处,seo自动工具,上海网站推,深圳小程序外包开发题目 给你一棵根为 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/154530.html

相关文章:

  • 网站建设专用图形库seo网站分析报告
  • 什么是域名解析百度seo还有前景吗
  • 二级域名免费网站怎么申请百度的网址是什么
  • wordpress 外链搜索框海阳seo排名优化培训
  • 公司网站流程南宁seo服务优化
  • 企业营销型网站推广方法广州百度seo排名优化
  • 广安做网站公司搜索关键词排行榜
  • 平板电脑可以做淘宝网站吗网络运营师资格证
  • 做网站内页图片尺寸广西百度seo
  • 商城网站建设多少钱网站推广平台
  • 运用django做网站免费二级域名建站
  • 襄阳网络公司 网站建设2345网址导航电脑版
  • 搜索网站 模板百度宣传做网站多少钱
  • 16岁学生免费开网店广州优化疫情防控举措
  • 青岛市专业做网站的吗福州seo按天付费
  • 陕西百威建设监理有限司网站免费推广方法有哪些
  • 关键字查询我的网站怎么做保定百度推广联系电话
  • 婚庆网站建设策划案费用预算如何做外贸网站的推广
  • 合肥做双语网站网站发布与推广方式
  • wordpress跳转链接插件汉化北京seo营销公司
  • 网站开发价格表公司网站建设平台
  • 网站404设置小红书怎么推广引流
  • php制作网站开发建站cms
  • 网络编程技术清华大学出版社答案关键词优化排名工具
  • 网站建设的源代码网络推广属于什么行业
  • 网站官网认证加v怎么做关键词seo排名怎么样
  • 美食网站建设规划书需求分析北京seo
  • 中国摄影师个人网站设计大数据智能营销
  • 网络营销客户的心里特征网络seo优化平台
  • 有哪些好的网站建设搜索引擎优化自然排名的优点