JavaScript实现多叉树的递归遍历和非递归遍历算法操作示例


Posted in Javascript onFebruary 08, 2018

本文实例讲述了JavaScript实现多叉树的递归遍历和非递归遍历算法操作。分享给大家供大家参考,具体如下:

演示之前的准备工作

演示项目的文件结构:

index.html
jsonData.js
recurrenceTree.js
noRecurrenceTree.js

解释一下各个文件:

index.html 是用来演示的 HTML 文件。
jsonData.js 里面存储着多叉树的JSON数据。
recurrenceTree.js 递归算法遍历树。
noRecurrenceTree.js 非递归算法遍历树。

jsonData.js

/**
 * 用于演示的 JSON 树形数据结构
 */
var root = {
  name:'D盘',
  children:[
    {
      name:'学习',
      children:[
        {
          name:'电子书',
          children:[
            {
              name:'文学',
              children:[
                {
                  name:'茶馆'
                },
                {
                 name:'红与黑'
                }
              ]
            }
          ]
        }
      ]
    },
    {
      name:'电影',
      children:[
        {
          name:'美国电影'
        },
        {
          name:'日本电影'
        }
      ]
    }
  ]
}

index.html

<!DOCTYPE html>
<html lang="en">
 <head>
  <meta charset="UTF-8">
  <meta name="renderer" content="webkit"/>
  <meta http-equiv="x-ua-compatible" content="ie=edge, chrome=1">
  <meta http-equiv="Cache-Control" content="max-age: 31536000">
  <title>3water.com js多叉树遍历</title>
  <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no">
  <meta name="wap-font-scale" content="no">
  <meta name="author" content="">
  <meta name="keywords" content="">
  <meta name="description" content="">
  <script type="text/javascript" src="jsonData.js"></script>
 </head>
 <body>
  递归遍历:<span id="app"></span>
  <script type="text/javascript" src="recurrenceTree.js"></script>
  <hr>
  非递归遍历:<span id="app2"></span>
  <script type="text/javascript" src="noRecurrenceTree.js"></script>
 </body>
</html>

递归遍历

recurrenceTree.js

// 遍历单个节点
function traverseNode(node){
  var divObj = document.getElementById("app");
  divObj.innerHTML = divObj.innerHTML + " " + node.name;
}
// 递归遍历树
// 作者:张超
function traverseTree(node){
  if (!node) {
    return;
  }
  traverseNode(node);
  if (node.children && node.children.length > 0) {
    var i = 0;
    for (i = 0; i < node.children.length; i++) {
      this.traverseTree(node.children[i]);
    }
  }
}
traverseTree(root);

非递归遍历

noRecurrenceTree.js

// 遍历单个节点
function traverseNode2(node){
  var divObj2 = document.getElementById("app2");
  divObj2.innerHTML = divObj2.innerHTML + " " + node.name;
}
// 非递归遍历树
// 作者:张超
function traverseTree2(node){
  if (!node) {
    return;
  }
  var stack = [];
  stack.push(node);
  var tmpNode;
  while (stack.length > 0) {
    tmpNode = stack.pop();
    traverseNode2(tmpNode);
    if (tmpNode.children && tmpNode.children.length > 0) {
      var i = tmpNode.children.length - 1;
      for (i = tmpNode.children.length - 1; i >= 0; i--) {
        stack.push(tmpNode.children[i]);
      }
    }
  }
}
traverseTree2(root);

本机测试效果:

JavaScript实现多叉树的递归遍历和非递归遍历算法操作示例

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JavaScript中创建类/对象的几种方法总结
Nov 29 Javascript
jquery中获取元素里某一特定子元素的代码
Dec 02 Javascript
javascirpt实现2个iframe之间传值的方法
Jun 30 Javascript
js获取当前时间(昨天、今天、明天)
Nov 23 Javascript
基于js实现二级下拉联动
Dec 17 Javascript
Bootstrap实现基于carousel.js框架的轮播图效果
May 02 Javascript
angularjs封装$http为factory的方法
May 18 Javascript
vue2.x 父组件监听子组件事件并传回信息的方法
Jul 17 Javascript
seajs中最常用的7个功能、配置示例
Oct 10 Javascript
iView框架问题整理小结
Oct 16 Javascript
微信小程序中转义字符的处理方法
Mar 28 Javascript
vue请求服务器数据后绑定不上的解决方法
Oct 30 Javascript
在vue项目中使用element-ui的Upload上传组件的示例
Feb 08 #Javascript
vue中实现methods一个方法调用另外一个方法
Feb 08 #Javascript
使用vux实现上拉刷新功能遇到的坑
Feb 08 #Javascript
jQuery实现的简单图片轮播效果完整示例
Feb 08 #jQuery
jQuery 防止相同的事件快速重复触发方法
Feb 08 #jQuery
AnglarJs中的上拉加载实现代码
Feb 08 #Javascript
利用vue.js实现被选中状态的改变方法
Feb 08 #Javascript
You might like
php正则表达式学习笔记
2015/11/13 PHP
PHP怎样用正则抓取页面中的网址
2016/08/09 PHP
Some tips of wmi scripting in jscript (1)
2007/04/03 Javascript
JavaScript 快捷键设置实现代码
2009/03/13 Javascript
jquery.validate分组验证代码
2011/03/17 Javascript
Javascript学习笔记 delete运算符
2011/09/13 Javascript
js弹出确认是否删除对话框
2014/03/27 Javascript
js实现动态创建的元素绑定事件
2016/07/19 Javascript
详解获取jq ul第一个li定位的四种解决方案
2016/11/23 Javascript
解析ajaxFileUpload 异步上传文件简单使用
2016/12/30 Javascript
js仿iphone秒表功能 计算平均数
2017/01/11 Javascript
Vue 单文件中的数据传递示例
2017/03/21 Javascript
vue仿淘宝订单状态的tab切换效果
2020/06/23 Javascript
浅谈Node.js 中间件模式
2018/06/12 Javascript
微信小程序实现的绘制table表格功能示例
2019/04/26 Javascript
ES6 Promise对象的应用实例分析
2019/06/27 Javascript
python数据类型_字符串常用操作(详解)
2017/05/30 Python
Python实现图片转字符画的示例
2017/08/22 Python
python删除文本中行数标签的方法
2018/05/31 Python
Django分页查询并返回jsons数据(中文乱码解决方法)
2018/08/02 Python
解决Python3 抓取微信账单信息问题
2019/07/19 Python
Laravel框架表单验证格式化输出的方法
2019/09/25 Python
浅谈python3打包与拆包在函数的应用详解
2020/05/02 Python
keras 实现轻量级网络ShuffleNet教程
2020/06/19 Python
Python不支持 i ++ 语法的原因解析
2020/07/22 Python
Spartoo荷兰:鞋子、包包和服装
2018/07/12 全球购物
巴西最大的玩具连锁店:Ri Happy
2020/06/17 全球购物
模具专业推荐信
2013/10/30 职场文书
集团公司总经理岗位职责
2013/12/20 职场文书
警示教育活动总结
2014/05/05 职场文书
解除财产保全担保书
2014/05/20 职场文书
党员自我对照检查材料
2014/08/19 职场文书
普通党员对照检查材料
2014/09/24 职场文书
确保工程质量承诺书
2015/04/29 职场文书
消费者投诉书范文
2015/07/02 职场文书
html原生table实现合并单元格以及合并表头的示例代码
2023/05/07 HTML / CSS