js二叉树的遍历算法是怎样的

发布时间:2021-10-13 13:56:49 作者:柒染
来源:亿速云 阅读:115

js二叉树的遍历算法是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

  二叉树的遍历算法有什么

  二叉树呐,有三种遍历算法,1:中序遍历,2:先序遍历,3:后序遍历。在我们看具体实现之前,我们想下为什么要这样做?二叉树广泛应用于大量数据查找的业务中,可以实现更高效率的查找。

  1:中序遍历,即先查找左节点,接着查找根节点,最后查找右节点。不论中序,先序,后序都是以根节点为依据的。下面上代码

  functioninOrder(node){

  if(!node===null&&nodeinstanceofBst)

  inOrder(node.left)

  console.log(node.data)

  inOrder(node.right)

  }

  2:先序遍历:

  functioninOrder(node){

  if(!node===null&&nodeinstanceofBst)

  console.log(node.data)

  inOrder(node.left)

  inOrder(node.right)

  }

  后序遍历类似,相信大家也能招到一定规律了。

  二叉树的遍历概念

  首先我们要知道前序遍历:中序遍历,后序遍历的概念:

  前序遍历:从双亲节点开始,遍历左树,再遍历右树;

  中序遍历:从左树开始,再遍历双亲节点,最后遍历右树;

  后序遍历:从左树开始,再遍历右树,最后遍历双亲节点;

  核心算法很简单:创建一个数组,将当前的节点递归,算法不同处只是在于数组加入node节点的次序不一样:

  //前序算法

  functionbeforeErgodic(node){

  if(!!node){

  arr.push(node);

  beforeErgodic(node.firstElementChild);

  beforeErgodic(node.lastElementChild);

  }

  }

  //中序算法

  functionmiddleErgodic(node){

  if(!!node){

  middleErgodic(node.firstElementChild);

  arr.push(node);

  middleErgodic(node.lastElementChild);

  }

  }

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

推荐阅读:
  1. 用java实现二叉树的遍历算法
  2. 什么是KMP算法

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

js

上一篇:如何使用swift类多态

下一篇:bash循环中变量作用范围的示例分析

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》