全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript数据结构之二叉树的删除算法示例

本文实例讲述了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  # 数据结构  # 二叉树  # 删除  # 算法  # JS实现二叉查找树的建立以及一些遍历方法实现  # JavaScript数据结构之二叉查找树的定义与表示方法  # JavaScript数据结构与算法之二叉树实现查找最小值、最大值、给定值算法示例  # JavaScript实现二叉树定义、遍历及查找的方法详解  # JavaScript数据结构之二叉树的查找算法示例  # JS实现的二叉树算法完整实例  # JavaScript实现二叉树的先序、中序及后序遍历方法详解  # javascript实现二叉树遍历的代码  # Javascript实现从小到大的数组转换成二叉搜索树  # JavaScript实现的DOM树遍历方法详解【二叉DOM树、多叉DOM树】  # JavaScript数据结构之二叉树的遍历算法示例  # JS中的算法与数据结构之二叉查找树(Binary Sort Tree)实例详解  # 如果没有  # 树上  # 最小值  # 相关内容  # 两种  # 遍历  # 只需  # 感兴趣  # 我们可以  # 给大家  # 然后再  # 使其  # 只有一个  # 就得  # 要将  # 更多关于  # 所述  # 程序设计  # 为空 


相关文章: 北京专业网站制作设计师招聘,北京白云观官方网站?  建站之星下载版如何获取与安装?  网站制作价目表怎么做,珍爱网婚介费用多少?  个人网站制作流程图片大全,个人网站如何注销?  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  香港服务器如何优化才能显著提升网站加载速度?  定制建站如何定义?其核心优势是什么?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  如何快速查询网址的建站时间与历史轨迹?  简历在线制作网站免费版,如何创建个人简历?  行程制作网站有哪些,第三方机票电子行程单怎么开?  如何实现建站之星域名转发设置?  c# 在高并发下使用反射发射(Reflection.Emit)的性能  C++如何使用std::optional?(处理可选值)  青岛网站建设如何选择本地服务器?  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  建站上传速度慢?如何优化加速网站加载效率?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  如何确认建站备案号应放置的具体位置?  为什么Go需要go mod文件_Go go mod文件作用说明  长沙做网站要多少钱,长沙国安网络怎么样?  安徽网站建设与外贸建站服务专业定制方案  如何在Mac上搭建Golang开发环境_使用Homebrew安装和管理Go版本  如何通过虚拟机搭建网站?详细步骤解析  css网站制作参考文献有哪些,易聊怎么注册?  教学论文网站制作软件有哪些,写论文用什么软件 ?  建站之星如何实现PC+手机+微信网站五合一建站?  公司网站的制作公司,企业网站制作基本流程有哪些?  制作国外网站的软件,国外有哪些比较优质的网站推荐?  IOS倒计时设置UIButton标题title的抖动问题  建站之星×万网:智能建站系统+自助建站平台一键生成  如何访问已购建站主机并解决登录问题?  Python路径拼接规范_跨平台处理说明【指导】  建站之星ASP如何实现CMS高效搭建与安全管理?  中山网站制作网页,中山新生登记系统登记流程?  建站之星导航如何优化提升用户体验?  网站制作免费,什么网站能看正片电影?  h5在线制作网站电脑版下载,h5网页制作软件?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  seo网站制作优化,网站SEO优化步骤有哪些?  建站主机如何选?高性价比方案全解析  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  如何注册花生壳免费域名并搭建个人网站?  建站之星备案是否影响网站上线时间?  如何高效利用200m空间完成建站?  如何挑选优质建站一级代理提升网站排名?  独立制作一个网站多少钱,建立网站需要花多少钱?  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  文字头像制作网站推荐软件,醒图能自动配文字吗?  香港服务器网站推广:SEO优化与外贸独立站搭建策略 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。