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

一比一高仿手表网站国内永久免费建站

一比一高仿手表网站,国内永久免费建站,wordpress的使用方法,wordpress正在建设中题目 给定一个二叉树的根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。 一、代码实现 type TreeNode struct {Val intLeft *TreeNodeRight *TreeNode }func rightSideView(root *TreeNode) []int {i…

题目

给定一个二叉树的根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。

一、代码实现

type TreeNode struct {Val intLeft *TreeNodeRight *TreeNode
}func rightSideView(root *TreeNode) []int {if root == nil {return []int{}}var result []intqueue := []*TreeNode{root}for len(queue) > 0 {levelSize := len(queue)for i := 0; i < levelSize; i++ {node := queue[0]queue = queue[1:]if i == levelSize-1 {result = append(result, node.Val)}if node.Left != nil {queue = append(queue, node.Left)}if node.Right != nil {queue = append(queue, node.Right)}}}return result
}

二、算法分析

1. 核心思路
  • 层次遍历(BFS):利用队列进行广度优先搜索,记录每层最后一个节点值
  • 右视图特性:每层最右侧节点即为该层可见的节点
2. 关键步骤
  1. 队列初始化:根节点入队
  2. 层级遍历:记录当前层节点数,遍历时保留下一层节点
  3. 右节点捕获:当遍历到当前层最后一个节点时记录值
  4. 子节点入队:按顺序处理左右子节点
3. 复杂度
指标说明
时间复杂度O(n)每个节点遍历一次
空间复杂度O(n)队列最大存储空间为最宽层节点数

三、图解示例

在这里插入图片描述

四、边界条件与扩展

1. 特殊场景验证
  • 空树:返回空数组
  • 完全左斜树:返回根节点到最底层左节点的路径
  • 单节点树:返回单个元素的数组
2. 多语言实现
class TreeNode:def __init__(self, val=0, left=None, right=None):self.val = valself.left = leftself.right = rightclass Solution:def rightSideView(self, root: TreeNode) -> List[int]:if not root:return []result = []queue = [root]while queue:level_size = len(queue)for i in range(level_size):node = queue.pop(0)if i == level_size - 1:result.append(node.val)if node.left:queue.append(node.left)if node.right:queue.append(node.right)return result
class TreeNode {int val;TreeNode left;TreeNode right;TreeNode(int x) { val = x; }
}class Solution {public List<Integer> rightSideView(TreeNode root) {List<Integer> result = new ArrayList<>();if (root == null) return result;Queue<TreeNode> queue = new LinkedList<>();queue.offer(root);while (!queue.isEmpty()) {int levelSize = queue.size();for (int i = 0; i < levelSize; i++) {TreeNode node = queue.poll();if (i == levelSize - 1) {result.add(node.val);}if (node.left != null) queue.offer(node.left);if (node.right != null) queue.offer(node.right);}}return result;}
}

五、总结与扩展

1. 核心创新点
  • 层级遍历特性:利用BFS天然的分层特性获取右视图
  • 高效判断逻辑:通过层级索引直接定位最右节点
2. 扩展应用
  • 左视图:改为记录每层第一个节点
  • 对角线视图:修改节点入队顺序和记录策略
  • Z型遍历:结合层级奇偶性改变遍历方向
3. 工程优化
  • 双向队列:使用Deque提升出队效率
  • 层级缓存:预先缓存层级大小避免动态计算
  • 内存优化:每层处理完后及时释放引用
http://www.dtcms.com/wzjs/336017.html

相关文章:

  • 动漫做a视频网站2020国内搜索引擎排行榜
  • 百度怎么推广自己的网站cpa推广联盟平台
  • 做包子网站站长素材网
  • 公司企业网站设计尺寸百度我的订单查询
  • 洛阳哪家网站做的好购物网站哪个最好
  • 做logo那个网站合肥网络优化公司有几家
  • 南阳政府做网站推广吗怎么进行网络营销
  • 做二手机网站站长统计app软件下载
  • 标签云wordpress独立站seo实操
  • 网站平台设计百度开放平台登录
  • 做微信公众号网站源码seo优化报告
  • 做消费信贷网站价格软文网站推广法
  • 链接网站怎么做本地推荐本地推荐
  • 深圳网站建设 设计seo教程免费
  • 一学一做专题网站百度app安装
  • 网站建设 服务器 预算报价清单百度网盘pc网页版入口
  • 济南新站seo外包百度网站首页
  • 开发网站大概要多少钱近三天新闻50字左右
  • py可以做网站吗网站制作软件免费下载
  • 国外网站模板欣赏win10最强性能优化设置
  • 传奇游戏电脑版seo网络营销推广公司深圳
  • 沈阳科技网站建设网络营销推广活动
  • 高端网站设计有哪些如何做好网络销售技巧
  • 网站宣传推广平台今日小说排行榜百度搜索风云榜
  • 杭州网站建设费用多少目录型搜索引擎有哪些
  • 其他公司做的网站系统没授权能用吗友情链接多少钱一个
  • 怎么用织梦来做网站后台电子商务说白了就是干什么的
  • 微网站设计平台付费恶意点击软件
  • 网页编程语言有哪几种湖南专业seo公司
  • 做网站需要懂代码么上海关键词优化排名软件