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

网站建设规划毕业论文今天重大新闻国内最新消息

网站建设规划毕业论文,今天重大新闻国内最新消息,网站建设功能分为几种,wordpress去掉版权信息1.问题 给定一个二叉树的 根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。 示例 1: 输入: [1,2,3,null,5,null,4] 输出: [1,3,4] 示例 2: 输入: [1,null,3] 输出: [1,3] 示例 3: 输入: [] 输出: []…

1.问题

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

示例 1:

在这里插入图片描述

输入: [1,2,3,null,5,null,4]
输出: [1,3,4]

示例 2:

输入: [1,null,3]
输出: [1,3]

示例 3:

输入: []
输出: []

提示:

  • 二叉树的节点个数的范围是 [0,100]
  • -100 <= Node.val <= 100

2.解题思路

经历过前面几篇关于二叉树的层序遍历算法之后(参见102.二叉树的层序遍历,107.二叉树的层序遍历II),非常容易的就可以通过这种算法解答此题,基本思想就是围绕队列性质,广度优先算法解决。当然,深度优先算法也是可以解决的。

2.1 广度优先(BFS)

利用队列,遍历每层节点,并记录每层最后一个元素,直到遍历完最后一层,即可得到结果。访问顺序如下图所示:
在这里插入图片描述
红色结点自上而下组成答案,边缘以访问顺序标号。
复杂度

  • 时间复杂度: O(N),每个节点都入队出队了 1 次。
  • 空间复杂度: O(N),使用了额外的队列空间。

2.2 深度优先(DFS)

1)优先访问右子树,即访问顺序为:根-右-左;
2)如果当前节点所在深度还没有出现在res里(因为一层就一个节点),说明在该深度下当前节点是第一个被访问的节点,因此将当前节点加入res中。

if len(res) < depth:res.append(root.val)
# 遍历右子树
if root.right:dfs(root.right, depth + 1, res)
# 遍历左子树
if root.left:dfs(root.left, depth + 1, res)

复杂度

  • 时间复杂度: O(N),每个节点都访问了 1 次。
  • 空间复杂度: O(N),因为这不是一棵平衡二叉树,二叉树的深度最少是 logN, 最坏的情况下会退化成一条链表,深度就是N,因此递归时使用的栈空间是 O(N) 的。

3.代码

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {/**广度优先1.利用层序遍历思想,统计每层最后一个元素,即为答案2.分层标识*/public List<Integer> rightSideView2(TreeNode root) {//空节点if(null==root){return new ArrayList<>();}List<Integer> res=new ArrayList();//每层的遍历结果集List<Integer> tmp=new ArrayList();TreeNode node;//队列Queue<TreeNode> q=new LinkedList();//入队q.add(root);//分层标识q.add(null);while(!q.isEmpty()){node=q.poll();if(null!=node){tmp.add(node.val);//左右子树入队if(null!=node.left){q.add(node.left);}if(null!=node.right){q.add(node.right);}}//否层,该层遍历完毕else{if(!tmp.isEmpty()){//收集每层最后一个元素res.add(tmp.get(tmp.size()-1));tmp=new ArrayList();q.add(null);}}}return res;}//深度优先,递归public List<Integer> rightSideView(TreeNode root) {//判空if(null==root){return new ArrayList();}List<Integer> res=new ArrayList();dfs(root, 0, res);return res;}private void dfs(TreeNode root, int depth, List<Integer> res){if(res.size()==depth){res.add(root.val);}//左右子树,先遍历右子树,然后左子树if(null!=root.right){dfs(root.right, depth+1, res);}if(null!=root.left){dfs(root.left, depth+1, res);}}
}
http://www.ds6.com.cn/news/38265.html

相关文章:

  • 简洁页面心情网站专业放心关键词优化参考价格
  • 如何打开建设网站后台做网站排名服务热线
  • 深圳建站公司需要多久最新一周新闻
  • flask做的网站项目镇江关键字优化品牌
  • wordpress特色图尺寸武汉seo 网络推广
  • 网站做优化应该具备什么如何查询域名注册人信息
  • 手机网站建设域名空间东莞seo网络优化
  • 廊坊网站建设咨询青橙网络东莞推广
  • 北京网络网站建设价格低整站优化
  • 网站建设swot市场分析百度客服号码
  • 西双版纳傣族自治州有几个县高平网站优化公司
  • 网站制作多少钱啊火星时代教育培训机构怎么样
  • 微官网怎么关注seo也成搜索引擎优化
  • 六安网络科技股份有限公司金华百度seo
  • 党务公开网站建设百度搜索优化建议
  • 九江做网站哪家公司好免费推广网站大全集合
  • 做网站后端的是什么部门百度seo咋做
  • 网站优怎么做广告设计网站
  • 临淄网站建设手游推广个人合作平台
  • 自己设计小程序seo赚钱方式
  • 部队涨工资权威发布重庆自动seo
  • 网站建设收费流程快速网站搭建
  • 庐江县住房和城乡建设局网站seo诊断分析在线工具
  • h5自适应企业网站源码推广策略可以分为哪三种
  • 网站建设服务哪个便宜啊html模板网站
  • 宁波网站推广公司排名怎么买到精准客户的电话
  • 如何防止php网站被挂马百度动态排名软件
  • 北仑网站推广浙江专业网站seo
  • 自己做时时彩网站百度平台推广联系方式
  • 临沂哪里做网站比较好新品上市怎么推广词