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

网站建设管理后台导航栏wordpress网址修改

网站建设管理后台导航栏,wordpress网址修改,阿里云配置wordpress,wordpress get author meta说在前面 🎈二叉树大家应该都很熟了吧,那二叉树的这五种遍历方式你们都会了吗? 以这一二叉树为例子,我们来看看不同遍历方式返回的结果都是怎样的。 前序遍历 前序遍历的顺序是:首先访问根节点,然后递归地…

说在前面

🎈二叉树大家应该都很熟了吧,那二叉树的这五种遍历方式你们都会了吗?

以这一二叉树为例子,我们来看看不同遍历方式返回的结果都是怎样的。

前序遍历

前序遍历的顺序是:首先访问根节点,然后递归地遍历左子树,最后递归地遍历右子树。

var preorderTraversal = function(root) {const res = [];const traversal = (r)=>{if (r === null) return;res.push(r.val); // 访问根节点traversal(r.left); // 遍历左子树traversal(r.right); // 遍历右子树};traversal(root);return res;
};
  • 输出结果
[3,9,20,15,7]

中序遍历

中序遍历的顺序是:首先递归地遍历左子树,然后访问根节点,最后递归地遍历右子树。

var inorderTraversal = function(root) {const res = [];const traversal = (r)=>{if (r === null) return;traversal(r.left); // 遍历左子树res.push(r.val); // 访问根节点traversal(r.right); // 遍历右子树};traversal(root);return res;
};
  • 输出结果
[9,3,15,20,7]

后序遍历

后序遍历的顺序是:首先递归地遍历左子树,然后递归地遍历右子树,最后访问根节点。

var postorderTraversal = function(root) {const res = [];const traversal = (r)=>{if (r === null) return;traversal(r.left); // 遍历左子树traversal(r.right); // 遍历右子树res.push(r.val); // 访问根节点};traversal(root);return res;
};
  • 输出结果
[9,15,7,20,3]

层序遍历

层序遍历按照从上到下、从左到右的顺序访问二叉树的所有节点。

以广度优先策略遍历节点的方法:

  • 使用队列作为辅助数据结构。
  • 按照节点的深度层次访问二叉树,从根节点开始,逐层向下。
var levelOrderTraversal = function(root) {const res = [];const queue = [root];if(!root) return [];while(queue.length > 0){const node = queue.shift();res.push(node.val);node.left && queue.push(node.left);node.right && queue.push(node.right);}return res;
};
  • 输出结果
[3,9,20,15,7]

垂序遍历

对位于 (row, col) 的每个结点而言,其左右子结点分别位于 (row + 1, col - 1) 和 (row + 1, col + 1) 。树的根结点位于 (0, 0) 。

二叉树的 垂序遍历 从最左边的列开始直到最右边的列结束,按列索引每一列上的所有结点,形成一个按出现位置从上到下排序的有序列表。如果同行同列上有多个结点,则按结点的值从小到大进行排序。

在层序遍历的基础上记录每个数据所在的位置再重新进行排序即可。

var verticalTraversal = function (root) {const nodeList = [];const q = [{ node: root, row: 0, col: 0 }];//获取二叉树节点集合while (q.length) {const { node, row, col } = q.shift();nodeList.push({ val: node.val, row: row, col });if (node.left) q.push({ node: node.left, row: row - 1, col: col + 1 });if (node.right) q.push({ node: node.right, row: row + 1, col: col + 1 });}//对二叉树节点进行排序nodeList.sort((a, b) => {if (a.row === b.row && a.col === b.col) {return a.val - b.val;}return a.row - b.row;});//对二叉树节点进行分组const res = [[nodeList[0].val]];for (let i = 1; i < nodeList.length; i++) {if (nodeList[i].row !== nodeList[i - 1].row) {res.push([]);}res[res.length - 1].push(nodeList[i].val);}return res;
};
  • 输出结果
[[9],[3,15],[20],[7]]

公众号

关注公众号『前端也能这么有趣』,获取更多有趣内容。

说在后面

🎉 这里是 JYeontu,现在是一名前端工程师,有空会刷刷算法题,平时喜欢打羽毛球 🏸 ,平时也喜欢写些东西,既为自己记录 📋,也希望可以对大家有那么一丢丢的帮助,写的不好望多多谅解 🙇,写错的地方望指出,定会认真改进 😊,偶尔也会在自己的公众号『前端也能这么有趣』发一些比较有趣的文章,有兴趣的也可以关注下。在此谢谢大家的支持,我们下文再见 🙌。

http://www.yayakq.cn/news/755234/

相关文章:

  • 七牛搭建网站导航网址网站怎么做
  • 多语言 网站源码湖北seo服务
  • 佛山做外贸网站如何建设工程合同索赔的原因有哪些
  • dedecms 门户网站网站怎么添加js广告位
  • 黎城网站建设佛山企业如何建网站
  • 网站建设ui设计公司wordpress调用自定义文章类型
  • 做网站用linux哪个版本什么是网站的推广
  • 皂君庙网站建设优秀的网页模板网站
  • 江门建设局网站流程设计网站
  • 常德网站建设开发哪家好网站关键词在哪里做
  • 中宁建设局网站模板网站建设 百度
  • 大连可以做网站的公司网站登录页面模板
  • 如何借助网站打广告黄陂建设网站
  • 面包屑 网站手机软件下载大全
  • 台州住房和城乡建设部网站网页制作方案策划
  • 东莞网站建设工作室推广方案怎么写
  • 外贸网站模板源码公司网站备案号
  • 在百度上做购物网站网站开发持续更新
  • 如何建设cpa影视网站大力推进网站集约化建设
  • 有没有IT做兼职的网站黄冈黄页88网黄冈房产估价
  • dedecms_v5.6室内装饰设计公司企业网站模板.rar网站收录率
  • 无锡高端网站建设公司天津校园文化设计公司
  • 铜陵网站建设哪家好广告代理公司
  • 外汇平台+网站开发昆山品牌网站
  • 网站设计高怎么表示泰安集团网站建设流程
  • 现在中国空间站有几个人wordpress数据库修改主题
  • 官网网站系统仟亿网络科技工作室
  • 上海网站建设的价格是多少钱Audiology wordpress
  • 电子商务公司设计网站建设做三方网站多少钱
  • 高端网站设计报价表wordpress 三栏