JavaScript数据结构之二叉树的删除算法示例
2017-04-13 09:53
603 查看
本文实例讲述了JavaScript数据结构之二叉树的删除算法。分享给大家供大家参考,具体如下:
从二叉查找树上删除节点的操作复杂程度取决于删除哪个节点。如果删除没有子节点的节点就非常简单,如果节点只有一个子节点,不管是左子节点还是右子节点,就变得稍微有点复杂,如果节点包含两个子节点就最复杂。
如果待删除节点是叶子节点,那么只需要将从父节点指向它的链接指向null。
如果待删除节点只包含一个子节点,那么原本指向它的节点就得使其指向它的子节点。
如果待删除节点包含两个子节点,那么我们可以采用两种方式,一种是查找待删除节点左子树上的最大值,一种是查找待删除节点右节点上的最小值。我们采取后者,找到最小值后,将临时节点上的值复制到待删除节点,然后再删除临时节点。
删除操作的代码如下:
function getSmallest(node){//查找最小节点 while(node.left!=null){ node=node.left; } return node; } function remove(data){ root=removeNode(this.root,data);//将根节点转换 } function removeNode(node,data){ if(node==null){ return null; } if(data==node.data){ //如果没有子节点 if(node.right==null&&node.left==null){ return null;//直接将节点设为空 } //如果没有左子节点 if(node.left==null){ return node.right;//直接指向其右节点 } //如果没有右子节点 if(node.right==null){ return node.left; } //如果有两个节点 if(node.right!=null&&node.left!=null){ var tempNode=getSmallest(node.right);//找到最小的右节点 node.data=tempNode.data; node.right=removeNode(node.right,tempNode.data);//依次寻找 return node; } }else if(data<node.data){ node.left=removeNode(node.left,data); return node; }else{ node.right=removeNode(node.right,data); return node; } }
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript数据结构与算法技巧总结》、《JavaScript数学运算用法总结》、《JavaScript排序算法总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- JavaScript数据结构之二叉树的遍历算法示例
- JavaScript数据结构之二叉树的计数算法示例
- JavaScript数据结构和算法之二叉树详解
- JavaScript数据结构之二叉树的查找算法示例
- 微软等数据结构+算法面试100题(20)--二叉树公共父节点
- 微软等数据结构+算法面试100题(4)--怎样从顶部开始逐层打印二叉树结点数据?请编程
- JavaScript节点的删除和重建示例代码!
- 数据结构和算法分析学习笔记(三)--二叉查找树的懒惰删除(lazy deletion)
- JAVASCRIPT和数据结构,算法
- 微软等数据结构+算法面试100题(36)-- 打印二叉树中某一层的节点
- 数据结构 算法面试100题 之 二叉树转换成双向链表
- 应用数据结构(一)线性表节点的插入和删除算法
- 微软等数据结构+算法面试100题(41)-- 二叉树的前序遍历
- 微软等数据结构+算法面试100题(29)--在字符串中删除特定的字符
- 微软等数据结构+算法面试100题(31)--在O(1)时间内删除链表结点
- 算法与数据结构--实现线性表的删除操作--算法2.4
- 数据结构与算法学习之二叉树的遍历:已知先序、中序、后序序列三者中的两种求另外一种遍历的算法
- 《Delphi 算法与数据结构》学习与感悟[8]: 单向链表的添加、删除与遍历
- JavaScript删除、移动和复制文件示例
- 微软等数据结构+算法面试100题(21)--二叉树打印到叶子节点的所有路径