• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 二叉查找树的插入,删除,查找

二叉查找树的插入,删除,查找

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了二叉查找树,二叉查找树的建立,最优二叉查找树,二叉查找树的删除,平衡二叉查找树等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

二叉查找树是满足以下条件的二叉树:
1、左子树上的所有节点值均小于根节点值,
2、右子树上的所有节点值均不小于根节点值,
3、左右子树也满足上述两个条件。

二叉查找树的插入过程如下:
1.若当前的二叉查找树为空,则插入的元素为根节点,
2.若插入的元素值小于根节点值,则将元素插入到左子树中,
3.若插入的元素值不小于根节点值,则将元素插入到右子树中。

二叉查找树的删除,分三种情况进行处理:
1.p为叶子节点,直接删除该节点,再修改其父节点的指针(注意分是根节点和不是根节点),如图a。

2.p为单支节点(即只有左子树或右子树)。让p的子树与p的父亲节点相连,删除p即可;(注意分是根节点和不是根节点);如图b。

3.p的左子树和右子树均不空。找到p的后继y,因为y一定没有左子树,所以可以删除y,并让y的父亲节点成为y的右子树的父亲节点,并用y的值代替p的值;或者方法二是找到p的前驱x,x一定没有右子树,所以可以删除x,并让x的父亲节点成为y的左子树的父亲节点。如图c。

  

插入节点的代码:

pnode BT = NULL;


//递归方法插入节点
pnode insert(pnode root, int x)
{
    pnode p = (pnode)malloc(LEN);
    p->val = x;
    p->lchild = NULL;
    p->rchild = NULL;
    if(root == NULL){
        root = p;   
    }   
    else if(x < root->val){
        root->lchild = insert(root->lchild, x);   
    }
    else{
        root->rchild = insert(root->rchild, x);   
    }
    return root;
}

//非递归方法插入节点
void insert_BST(pnode q, int x)
{
    pnode p = (pnode)malloc(LEN);
    p->val = x;
    p->lchild = NULL;
    p->rchild = NULL;
    if(q == NULL){
        BT = p;
        return ;   
    }       
    while(q->lchild != p && q->rchild != p){
        if(x < q->val){
            if(q->lchild){
                q = q->lchild;   
            }   
            else{
                q->lchild = p;
            }       
        }   
        else{
            if(q->rchild){
                q = q->rchild;   
            }   
            else{
                q->rchild = p;   
            }
        }
    }
    return;
}
</div>
查找节点的代码:
         &nb

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C语言 二叉查找树性质详解及实例代码
  • c++实现二叉查找树示例
  • 二叉查找树的插入,删除,查找

相关文章

  • 2017-05-28C++遗传算法类文件实例分析
  • 2017-05-28C语言main函数的参数及其返回值详细解析
  • 2017-05-28详解C++编程中的单目运算符重载与双目运算符重载
  • 2017-05-28linux C 打印错误信息和标准输入输出详细介绍
  • 2017-05-28C++常对象精讲_const关键字的用法
  • 2017-05-28C++中const用法小结
  • 2017-05-28C++中运算符 &和&&、|和|| 的详解及区别
  • 2017-05-28数据结构课程设计- 解析最少换车次数的问题详解
  • 2017-05-28解析C语言中位字段内存分配的问题
  • 2017-05-28C 语言基础教程(我的C之旅开始了)[十]

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 解决在Mac下直接解压C++静态库出现的问题
    • 详解C++中new运算符和delete运算符的使用
    • stringstream操纵string的方法总结
    • C++二进制翻转实例分析
    • C 语言基础教程(我的C之旅开始了)[七]
    • C++ 遍历目录下文件简单实现实例
    • 详细解析C语言中的开方实现
    • C/C++位操作实例总结
    • c语言中十六进制转二进制显示的实现方法
    • C/C++中可变参数的用法详细解析

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有