二叉查找树(二叉排序树)创建、插入、删除、查找-C语言

二叉查找树:或者是一颗空树;或者是具有以下性质的二叉树:(1)若它的左子树不为空,则左子树上所有结点的值都小于根结点的值;(2)若它的右子树不为空,则右子树所有结点的值均大于它的根结点的值;(3)左右子树分别为二叉查找树;

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#define N 7   //插入查找树数组长度 

/* 二叉查找树 操作*/
typedef int Elemtype;
typedef struct BSTNode
{
    Elemtype data;
    struct BSTNode *lchild,*rchild;
}BSTNode,*PNode;

//查找结点,树中存在结点值为data的结点返回true,否则返回false 
bool SearchBST(PNode T,Elemtype data)
{
    if(T == NULL)
        return false;
    if(data < T->data)
        return SearchBST(T->lchild,data);
    else if(data > T->data)
        return SearchBST(T->rchild,data);
    else 
        return true;    
 } 

 //向树中插入节点,若此节点在不在树中则插入,已在树中则不插入 
 PNode insertBST(Elemtype data,PNode root)
 {
    if(root == NULL)
    {
        root = (PNode)malloc(sizeof(BSTNode));
        root->data = data;
        root->lchild = NULL;
        root->rchild = NULL;
        printf("%d插入树中\n",data);
        return root;
     }
     if(data < root->data)
        root->lchild = insertBST(data,root->lchild);
     else if(data > root->data)
        root->rchild = insertBST(data,root->rchild);
     else
        printf("%d已在树中,不能再次插入!!!\n",data);
     return root;
 }

//查找二叉查找树中最大、最小节点值;从根节点开始查找左儿子,
//只要存在左儿子就一直查找,终点就是最小的元素,最大的为右儿子查找终点 
PNode findMin(PNode root)
{
    if(root == NULL)
        return NULL;
    else if(root->lchild == NULL)
        return root;
    return findMin(root->lchild);     //递归查找 
 } 

 PNode findMax(PNode root)
 {
    if(root != NULL)                   //非递归查找 
        while(root->rchild != NULL)
            root = root->rchild;
    return root;
 }

 //删除一个结点:如果是叶结点则直接删除;如果结点有一个孩子,
 //则直接用该结点父节点连接此结点孩子结点,删除此节点;如果结点有两个孩子结点
 //则用其右子树的最小数据代替该结点的数据并递归的删除那个最小结点,因为右子树的
 //最小结点不可能有左儿子因此第二次删除比较容易
 PNode deleteBST(PNode root,Elemtype data)
 {
    if(root == NULL)
        return root;

    if(data < root->data)
        root->lchild = deleteBST(root->lchild,data);
    else if(data > root->data)
        root->rchild = deleteBST(root->rchild,data);
    else if(root->lchild != NULL && root->rchild != NULL)
    {
        root->data = findMin(root->rchild)->data;
        root->rchild = deleteBST(root->rchild,root->data);
     }
     else
        root = (root->lchild != NULL) ? root->lchild : root->rchild;
    return root;
  } 

//中序输出:中序遍历二叉查找树可以得到原关键字有序序列 
void print(PNode root)
{
    if(root!=NULL)
    {
        print(root->lchild);
        printf("%d ",root->data);
        print(root->rchild);
    }
 } 

int main(int argc, char *argv[]) {
    Elemtype data[N] = {45,24,53,45,12,24,90};
    int i;
    PNode root = NULL; //二叉查找树根节点 
    for(i=0;i<N;i++)    //创建二叉查找树 
    {
        root = insertBST(data[i],root);
    }
    print(root);
    printf("\n");
    root = insertBST(55,root);
    print(root);
    printf("\n");
    root = deleteBST(root,24);
    print(root);
    printf("\n");
    return 0;
}
  • 9
    点赞
  • 84
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
好的,我来为您介绍一下如何使用C语言实现二叉排序树查找插入、建立、删除和打印。 1. 建立二叉排序树 我们可以通过以下代码来建立一棵二叉排序树: ```c typedef struct node { int data; // 数据域 struct node *left; // 左子树 struct node *right; // 右子树 } Node, *Tree; // 插入节点 void insertNode(Tree *t, int data) { if (*t == NULL) { *t = (Node*)malloc(sizeof(Node)); (*t)->data = data; (*t)->left = NULL; (*t)->right = NULL; } else if (data < (*t)->data) { insertNode(&((*t)->left), data); } else if (data > (*t)->data) { insertNode(&((*t)->right), data); } } // 建立二叉排序树 void createTree(Tree *t, int data[], int n) { int i; for (i = 0; i < n; i++) { insertNode(t, data[i]); } } ``` 这段代码中,我们定义了一个Node结构体表示二叉排序树的节点,其中包括数据域data和左右子树指针left和right。通过insertNode函数实现节点的插入,通过createTree函数实现二叉排序树的建立。 2. 查找节点 我们可以通过以下代码来查找二叉排序树中的某个节点: ```c // 查找节点 Node* searchNode(Tree t, int data) { if (t == NULL) { return NULL; } else if (data == t->data) { return t; } else if (data < t->data) { return searchNode(t->left, data); } else { return searchNode(t->right, data); } } ``` 这段代码中,我们通过递归的方式实现了查找节点的功能,如果节点为空则返回NULL,如果节点数据等于查找数据则返回该节点,如果查找数据小于节点数据则继续在左子树中查找,如果查找数据大于节点数据则继续在右子树中查找。 3. 插入节点 我们可以通过以下代码来向二叉排序树插入一个新节点: ```c // 插入节点 void insertNode(Tree *t, int data) { if (*t == NULL) { *t = (Node*)malloc(sizeof(Node)); (*t)->data = data; (*t)->left = NULL; (*t)->right = NULL; } else if (data < (*t)->data) { insertNode(&((*t)->left), data); } else if (data > (*t)->data) { insertNode(&((*t)->right), data); } } ``` 这段代码中,我们通过递归的方式实现了节点的插入功能,如果节点为空则创建一个新节点,如果插入数据小于节点数据则继续在左子树中插入,如果插入数据大于节点数据则继续在右子树中插入。 4. 删除节点 我们可以通过以下代码来删除二叉排序树中的某个节点: ```c // 删除节点 void deleteNode(Tree *t, int data) { Node *p; if (*t == NULL) { return; } else if (data < (*t)->data) { deleteNode(&((*t)->left), data); } else if (data > (*t)->data) { deleteNode(&((*t)->right), data); } else if ((*t)->left && (*t)->right) { p = findMax((*t)->left); (*t)->data = p->data; deleteNode(&((*t)->left), (*t)->data); } else { p = *t; if ((*t)->left == NULL) { *t = (*t)->right; } else if ((*t)->right == NULL) { *t = (*t)->left; } free(p); } } // 查找最大节点 Node* findMax(Tree t) { if (t == NULL) { return NULL; } else if (t->right == NULL) { return t; } else { return findMax(t->right); } } ``` 这段代码中,我们通过递归的方式实现了节点的删除功能,如果节点为空则返回,如果删除数据小于节点数据则继续在左子树中删除,如果删除数据大于节点数据则继续在右子树中删除,如果节点同时存在左右子树,则找到左子树中的最大节点并替换要删除的节点,然后在左子树中删除该节点,否则直接删除该节点。 5. 打印二叉排序树 我们可以通过以下代码来打印二叉排序树: ```c // 中序遍历打印二叉排序树 void printTree(Tree t) { if (t != NULL) { printTree(t->left); printf("%d ", t->data); printTree(t->right); } } ``` 这段代码中,我们通过中序遍历的方式实现了打印二叉排序树的功能,按照左子树、根节点、右子树的顺序打印节点数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值