• 二叉排序树


    一、定义

    二叉排序树又称作二叉查找树,它是一种对排序和查找都很有用的特殊二叉树。二叉排序树或者是一棵空树,或者是具有下列性质的二叉树:
    (1)若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
    (2)若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
    (3)它的左、右子树也分别为二叉排序树.
    由以上定义可得出:中序遍历一棵二叉树时可以得到一个结点值递增的有序序列

    二、二叉排序树的创建、查找、插入

    
    	//-----------二叉排序树的二叉链表存储形式-------------------
    	typedef int KeyType,InfoType;
    
    	//数据元素定义
    	typedef struct
    	{
    	    KeyType key;            //关键字域
    	    InfoType otherinfo;     //其他域
    	} ElemType;
    	//结点
    	typedef struct BSTNode
    	{
    	    ElemType data;
    	    struct BSTNode *lchild,*rchild;//左右子树
    	} BSTNode,*BSTree;
    	//插入二叉排序树
    	void InsertBST(BSTree &T,ElemType e)
    	{
    	    if(!T)
    	    {
    	        BSTree S = new BSTNode;
    	        S->data = e;
    	        S->lchild=S->rchild=NULL;
    	        T=S;
    	    }
    	    else if(T->data.key>e.key)
    	    {
    	        InsertBST(T->lchild,e);
    	    }
    	    else if(T->data.key<e.key)
    	    {
    	        InsertBST(T->rchild,e);
    	    }
    	}
    	#define ENDFLAG 0
    	//创建二叉排序树
    	void CreateBSTree(BSTree &T)
    	{
    	    ElemType e;
    	    T=NULL;
    	    cout << "输入key和value,0结束" << endl;
    	    cin >> e.key >> e.otherinfo;
    	    int i = 0;
    	    while(e.key!=ENDFLAG)
    	    {
    	        i++;
    	        InsertBST(T,e);
    	        cin >> e.key >> e.otherinfo;
    	    }
    	    cout << "创建成功,共有" << i << "个元素" << endl;
    	}
    	
    	
    	//查找二叉排序树
    	ElemType SearchBST(BSTree T,KeyType key)
    	{
    	    if(T)
    	    {
    	        if(T->data.key==key)
    	        {
    	            return T->data;
    	        }
    	        else if(T->data.key>key)
    	        {
    	            return SearchBST(T->lchild,key);
    	        }
    	        else if(T->data.key<key)
    	        {
    	            return SearchBST(T->rchild,key);
    	        }
    	    }
    	    else
    	    {
    	        ElemType e;
    	        e.key=-1;
    	        return e;
    	    }
    	
    	}
    
  • 相关阅读:
    maven父子项目
    编写简单的maven插件
    使用nexus搭建maven私服
    nexus安装
    Maven 配置tomcat和findbug插件(在eclipse建立的项目中)
    Maven打包时,不包含jar包
    pom文件解析
    android post(HTTP设置参数,仿html表单提交)
    在Eclipse中进行UI设计时xml界面横屏竖屏设置方法
    有声相机开发
  • 原文地址:https://www.cnblogs.com/HenuAJY/p/11007393.html
Copyright © 2020-2023  润新知