JavaScript 实现二叉树:

  1. // JavaScript 实现二叉树
  2.  
  3. function BinaryTree ()
  4. {
  5. var Node = function (key)
  6. {
  7. this.key = key;
  8. this.left = null;
  9. this.right = null;
  10. }
  11.  
  12. var root = null;
  13.  
  14. var insertNode = function (Node, newNode)
  15. {
  16. if (newNode.key < node.key) {
  17. if (node.left === null) {
  18. if (node.left === null) {
  19. node.left = newNode;
  20. } else {
  21. insertNode(node.left, newNode);
  22. }
  23. } else {
  24. if (node.right === null) {
  25. node.right = newNode;
  26. } else {
  27. insertNode(node.left, newNode);
  28. }
  29. } else {
  30. if (node.right === null) {
  31. node.right = newNode;
  32. } else {
  33. insertNode(node.right, newNode);
  34. }
  35. }
  36. }
  37.  
  38. this.insert = function (key)
  39. {
  40. var newNode = new Node(key);
  41. if (root === null) {
  42. root = node;
  43. } else {
  44. insertNode(root, newNode);
  45. }
  46. }
  47.  
  48. // 中序遍历
  49. var inOrderTraverseNode = function (node, callback)
  50. {
  51. if (node !== null) {
  52. inOrderTraverseNode(node.left, callback);
  53. callback(node.key);
  54. inOrderTraverseNode(node.right, callback);
  55. }
  56. }
  57.  
  58. this.inOrderTraverse = function (callback)
  59. {
  60. inOrderTraverseNode(root, callback);
  61. }
  62. }
  63. }
  64.  
  65. var nodes = [8, 3, 10, 1, 6, 14, 4, 7, 13];
  66. var binaryTree = new BinaryTree();
  67. nodes.forEach (function (key))
  68. {
  69. binaryTree.insert(key);
  70. }
  71.  
  72. var callback = function (key)
  73. {
  74. console.log(key);
  75. }
  76.  
  77. binaryTree.inOrderTraverse(callback);

JavaScript 实现二叉树的更多相关文章

  1. JavaScript实现二叉树算法

    二叉树的遍历方式 分别为中序遍历(左子树->当前节点->右子树).前序遍历(当前节点->左子树->右子树).后序遍历(左子树->右子树->当前节点).下面使用Jav ...

  2. javascript 搜索二叉树

    function Tree() { this.root = null; } Tree.prototype = { constructor: Tree, addItem: function(value) ...

  3. 每个JavaScript工程师都应懂的33个概念

    摘要: 基础很重要啊! 原文:33 concepts every JavaScript developer should know 译文:每个 JavaScript 工程师都应懂的33个概念 作者:s ...

  4. JS - 二叉树算法实现与遍历 (更新中...)

    一.关于二叉树: 截图来自:https://segmentfault.com/a/1190000000740261 温馨提示:学习以及使用二叉树概念,心中永远有这么一个图,对于理解和接受二叉树有很大的 ...

  5. 每个 JavaScript 工程师都应懂的33个概念

    简介 这个项目是为了帮助开发者掌握 JavaScript 概念而创立的.它不是必备,但在未来学习(JavaScript)中,可以作为一篇指南. 本篇文章是参照 @leonardomso 创立,英文版项 ...

  6. 用js 创建  简单查找 删除 二叉树

    <!DOCTYPE html> <html> <body> <canvas id="myCanvas" width="2000& ...

  7. ES6实现图片切换特效

    效果图 demo.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...

  8. javascript数据结构与算法-- 二叉树

    javascript数据结构与算法-- 二叉树 树是计算机科学中经常用到的一种数据结构.树是一种非线性的数据结构,以分成的方式存储数据,树被用来存储具有层级关系的数据,比如文件系统的文件,树还被用来存 ...

  9. 数据结构二叉树的递归与非递归遍历之java,javascript,php实现可编译(1)java

    前一段时间,学习数据结构的各种算法,概念不难理解,只是被C++的指针给弄的犯糊涂,于是用java,web,javascript,分别去实现数据结构的各种算法. 二叉树的遍历,本分享只是以二叉树中的先序 ...

随机推荐

  1. IE浏览器右键菜单插件开发(下篇)——如何用c#安装、卸载IE右键插件

    建立Installer安装类,如图: 代码如下: using Microsoft.Win32; using ResourceShare.UserClient.Common; using System; ...

  2. 10.socket网络编程

    套接字工作流程 先从服务器端说起.服务器端先初始化Socket,然后与端口绑定(bind),对端口进行监听(listen),调用accept阻塞,等待客户端连接.在这时如果有个客户端初始化一个Sock ...

  3. Linux shell 脚本(一)

    一.初识脚本 shell:一类介于系统内核与用户之间的解释程序.脚本:一类使用特定语言,按预设顺序执行的文件批处理.宏.解释型程序创建shell脚本:理清任务过程--整理执行语句--完善文件结构1.任 ...

  4. Spring服务定制

    问题总述 ​ 我们都知道如果使用Spring来进行bean管理的时候.如果同一个接口的实现类存在两个,直接使用@Autowired注解来实现bean注入,会在启动的时候报异常.我们通常的做法是使用@R ...

  5. 2017/11/25 2D变换

    2D变换 一.盒模型解析模式 1.box-sizing:盒模型解析模式 1)content-box:标准盒模型(和css2一样的计算) 宽度和高度之外绘制元素的内边距和边框 width,height外 ...

  6. Android开发从GC root分析内存泄漏

    我们常说的垃圾回收机制中会提到GC Roots这个词,也就是Java虚拟机中所有引用的根对象.我们都知道,垃圾回收器不会回收GC Roots以及那些被它们间接引用的对象.但是,对于GC Roots的定 ...

  7. [译文] SQL JOIN,你想知道的应该都有

    介绍 这是一篇阐述SQL JOINs的文章. 背景 我是个不喜欢抽象的人,一图胜千言.我在网上查找了所有的关于SQL JOIN的解释,但是没有找到一篇能用图像形象描述的. 有些是有图片的但是他们没有覆 ...

  8. 通过漫画轻松掌握HDFS工作原理

  9. MIP (百度移动网页加速器)

    前言:第一次用移动网页加速器,感觉好心情都被弄坏了.确实性能提高了不少,但是限制js,对于一些交互实现都成问题.MIP是Mobile Instant Pages的缩写,指百度移动网页加速器, 是一套应 ...

  10. Nginx正向代理与反向代理

    1.正向代理: 正向代理类似一个跳板机,代理访问外部资源. 典型应用:为在防火墙内的局域网客户端提供访问Internet的途径    如:IE例外设置代理服务器 正向代理配置实例:为不影响默认配置:添 ...