二叉排序樹的判定算法


/**********
【題目】試編寫一個二叉排序樹的判定算法。
二叉排序樹的類型BSTree定義如下:
typedef struct {
KeyType key;
... ... // 其他數據域
} TElemType;
typedef struct BiTNode {
TElemType data;
struct BSTNode *lchild, *rchild;
}BSTNode, *BSTree;
**********/

Status IsBSTree(BSTree T)
/* 判別二叉樹T是否為二叉排序樹。*/
/* 若是,則返回TRUE,否則FALSE  */
{
    if(T==NULL) return TRUE;    
    else{
        if(T->lchild==NULL&&T->rchild==NULL) return TRUE;
        else if((T->lchild->data.key<=T->data.key)&&(T->rchild->data.key>=T->data.key)) return (IsBSTree(T->lchild)&&IsBSTree(T->rchild));
        else return FALSE;
    }    
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM