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

企业网站优化链接北京专业网站制作服务标准

企业网站优化链接,北京专业网站制作服务标准,最新国际足球世界排名,建各企业网站多少钱文章目录理论基础二叉树的递归遍历前序遍历中序遍历后序遍历总结二叉树的层序遍历基础层序遍历二叉树的右视图理论基础 二叉树在结构上的两个常用类型: 满二叉树完全二叉树 在功能应用上的比较常用的有: 二叉搜索树: 节点有权值、遵循”左…

文章目录

  • 理论基础
  • 二叉树的递归遍历
    • 前序遍历
    • 中序遍历
    • 后序遍历
    • 总结
  • 二叉树的层序遍历
    • 基础层序遍历
    • 二叉树的右视图

理论基础

二叉树在结构上的两个常用类型:

  • 满二叉树
  • 完全二叉树

在功能应用上的比较常用的有:

  • 二叉搜索树: 节点有权值、遵循”左小右大“
  • 平衡二叉搜索树(AVL树): 在二叉树的基础上增添了一个特性,左右子树高度差不超过1

二叉树的存储方式

  • 顺序存储:使用数组,在内存中连续分布在这里插入图片描述

  • 链式存储:使用指针,在内存中离散分布在这里插入图片描述

二叉树的遍历方式

  • 深度优先遍历(可借助栈)
    • 前序遍历(递归法,迭代法)
    • 中序遍历(递归法,迭代法)
    • 后序遍历(递归法,迭代法)
  • 广度优先遍历(可借助队列)
    • 层序遍历(迭代法)

二叉树的定义

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;}
}

二叉树的递归遍历

前序遍历

题目链接:144. 二叉树的前序遍历

class Solution {public List<Integer> preorderTraversal(TreeNode root) {List<Integer> result = new ArrayList<>();preRead(root,result);return result;}public void preRead(TreeNode node,List<Integer> list){if(node == null) return;list.add(node.val);preRead(node.left,list);preRead(node.right,list);}
}

中序遍历

题目链接:94. 二叉树的中序遍历

class Solution {public List<Integer> inorderTraversal(TreeNode root) {List<Integer> result = new ArrayList<>();inRead(root,result);return result;}public void inRead(TreeNode node,List<Integer> list){if(node == null) return;inRead(node.left,list);list.add(node.val);inRead(node.right,list);}
}

后序遍历

题目链接:145. 二叉树的后序遍历

class Solution {public List<Integer> postorderTraversal(TreeNode root) {List<Integer> result = new ArrayList<>();postRead(root,result);return result;}public void postRead(TreeNode node,List<Integer> list){if(node == null) return;postRead(node.left,list);postRead(node.right,list);list.add(node.val);}
}

总结

递归算法的三要素

  • 确定递归函数的参数和返回值: 确定哪些参数是递归的过程中需要处理的,那么就在递归函数里加上这个参数, 并且还要明确每次递归的返回值是什么进而确定递归函数的返回类型。

    • 通过”参数传递“自顶向下传递信息
    • 通过”函数返回值“自底向上传递信息
    • 使用全局变量,在各级函数间共享信息
  • 确定终止条件: 写完了递归算法, 运行的时候,经常会遇到栈溢出的错误,就是没写终止条件或者终止条件写的不对,操作系统也是用一个栈的结构来保存每一层递归的信息,如果递归没有终止,操作系统的内存栈必然就会溢出。

  • 确定单层递归的逻辑: 确定每一层递归需要处理的信息。在这里也就会重复调用自己来实现递归的过程。

二叉树的层序遍历

基础层序遍历

题目链接:102. 二叉树的层序遍历

层序遍历的逻辑:

  • 初始化一个队列
  • 首先将根节点放入队列中
  • 接下来循环往复如下操作
    • 弹出队头元素
    • 将弹出元素的左右节点入队

这个题的要求在层序遍历的基础上增加了分层的逻辑,解题逻辑如下:

  • 在层序遍历的基础上
  • 我们再初始化一个队列temp(主队列命名为queue)
  • 我们在queue中把当前层的元素弹出时,并不立马将其左右元素入队queue,而是将其添加到temp队列中
  • 当queue中所有元素弹完之后,再将temp的元素全部添加到queue中
  • 这样就达成了queue中永远是二叉树中每层的所有元素

解题逻辑:

class Solution {public List<List<Integer>> levelOrder(TreeNode root) {List<List<Integer>> result = new ArrayList<>();Deque<TreeNode> queue = new ArrayDeque<>();if(root == null) return new ArrayList<List<Integer>>();queue.add(root);while(!queue.isEmpty()) {List<Integer> part = new ArrayList<>();Deque<TreeNode> temp = new ArrayDeque<>();while (!queue.isEmpty()) {TreeNode node = queue.poll();part.add(node.val);if(node.left != null) temp.add(node.left);if(node.right != null) temp.add(node.right);}result.add(part);while(!temp.isEmpty()) queue.add(temp.poll());}return result;}
}

这个地方可以进一步改进:

  • 无需使用新的队列来临时存储一层的元素
  • 而是可以直接用一个变量界定一层的元素个数
class Solution {public List<List<Integer>> levelOrder(TreeNode root) {List<List<Integer>> result = new LinkedList<>();Deque<TreeNode> queue = new ArrayDeque<>();if(root == null) return new ArrayList<List<Integer>>();queue.add(root);while(!queue.isEmpty()) {List<Integer> part = new LinkedList<>();int count = queue.size();while (count > 0) {TreeNode node = queue.poll();part.add(node.val);if(node.left != null) queue.add(node.left);if(node.right != null) queue.add(node.right);count--;}result.add(part);}return result;}
}

二叉树的右视图

题目链接:199. 二叉树的右视图

解题逻辑:

  • 在前一题的基础上只将每一层的最后一个元素添加到结果集中就可以
  • 我们通过控制每层的长度变量,当变量为1的时候才添加到结果集中
class Solution {public List<Integer> rightSideView(TreeNode root) {List<Integer> result = new LinkedList<>();Deque<TreeNode> queue = new ArrayDeque<>();if(root == null) return new ArrayList<Integer>();queue.add(root);while(!queue.isEmpty()) {int count = queue.size();while (count > 0) {TreeNode node = queue.poll();if(count == 1) result.add(node.val);if(node.left != null) queue.add(node.left);if(node.right != null) queue.add(node.right);count--;}}return result;}
}
http://www.dtcms.com/wzjs/546085.html

相关文章:

  • 郴州建设网站的公司网站设计制作价钱
  • 全站搜索资讯是做网站还是公众号
  • 企业网站制作一般多少钱平台推广策划
  • nodejs做企业网站旅游项目网站开发
  • seo如何做网站建设昆明网站设计公司
  • 青田网站做服装找工作asp网站图片
  • 做 理财网站浙江政务服务网登录入口
  • 网站推广搜索哪个网站找住宿的便宜
  • 做公司网站怎么删除图片网站一键备份
  • 淮安网站建设多少钱专门做试卷的网站
  • 网站方案书巩义网站建设联系电话
  • 一手房发帖网站怎样做建设工程合同法
  • 网站建设与维护中如果建设淘宝导购网站
  • 人工做流量的网站成品网站w灬源码1688
  • 做网站哪个便宜做网站来联盟怎么样
  • 前端怎么做电商网站wordpress theme demo
  • 投标建设用地是哪个网站购物网站怎么做SEO
  • 官方网站建设的四个步骤山东平台网站建设平台
  • 最好的ppt模板网站seo怎么做新手入门
  • 自己建一个网站需要多少钱?wordpress 获取摘要
  • 下载免费网站模板企业管理培训课程游戏
  • 公司名被注册网站电脑打开做的网站总显示404
  • 怎样设网站html5 自适应网站
  • 如何给自己网站做反链福建联美建设集团有限公司网站
  • 做视频网站挣钱吗推广费用一般多少钱
  • 外贸网站图片长春seo主管
  • 营销型企业网站建网通
  • 建站推广网站棋牌app开发公司
  • 免费公司网站主页模板wordpress那个版本好用
  • 网站建设顶呱呱中国建设银行网上银行个人登录官方网站