二叉查找树(BST)---拷贝 相等判断 查找节点 统计节点 统计层数 判断BST

// 拷贝树
void    copy_tree(TreeNode   *& dst,TreeNode  * src)  
{        
    
if( NULL==src)      
        dst
= NULL ;       
    
else        
    
{              
        dst
=(TreeNode *) malloc(sizeof(TreeNode));
        dst
->left = dst->right = NULL;
        dst
->value = src->value;            
        copy_tree(dst
->left,src->left);  
        copy_tree(dst
->right,src->right);     
    }
  
}

// 判断两棵二叉树是否相等
bool  equal_tree(TreeNode  * a, TreeNode  * b)
{
    
if (a == NULL && b == NULL) {
        
return true;
    }

    
    
if (a != NULL && b != NULL &&(a->value == b->value)&&
        equal_tree(a
->left, b->left) && equal_tree(a->right, b->right)) {
        
return true;
    }

    
else{
        
return false;
    }

}

// 查找节点
bool  find_node(TreeNode  * t,  int  value)
{
    
if( t == NULL )
        
return false;
    
if( t->value == value )
    
{
        
return true;
    }

    
if( t->value < value )
        
return find_node(t->left, value);
    
if(t->value > value)
        
return find_node(t->right, value);
}

// 查找父节点
TreeNode *  parent_node( int  value, TreeNode  * t)
{

    
if (t == NULL) {
        
return NULL;
    }


    
if (t->value == value)    //根节点
        return t;

    
if (t->left->value == value || 
        t
->right->value == value) //非根节点
        return t;
    }

    
else if (value < t->value) {
        
return parent_node(value, t->left);
    }

    
else if (value > t->value) {
        
return parent_node(value, t->right);
    }

    
    
return NULL;
}

// 统计节点个数
int  count_node(TreeNode  * t)
{
    
if (t == NULL) {
        
return 0;
    }

    
else{
        
return 1+count_node(t->left)+count_node(t->right);
    }

}

// 统计层数
int  level(TreeNode  * t)
{
    
int l=0, r=0;
    
if (t == NULL) {
        
return 0;
    }

    
else{
        
if (t->left != NULL) {
            l
=1+level(t->left);
        }

        
if (t->right != NULL) {
            r
=1+level(t->right);
        }
    
        
return l>r?l:r;
    }

}

// 判断是否为二叉排序树
bool  isbst(TreeNode  * t)
{
    
if ( t == NULL ) {
        
return true;
    }


    
if (isbst(t->left) && isbst(t->right) ) {
        
if ((t->left != NULL && t->right == NULL && t->value > t->left->value) ||
           (t
->right != NULL && t->left == NULL && t->value <= t->right->value) ||
           (t
->left != NULL && t->right != NULL && t->value > t->left->value && t->value <= t->right->value) ||
           (t
->left == NULL && t->right == NULL)){
                             
return true;            
        }

        
else{
            
return false;
        }

    }

    
else{
        
return false;
    }

}

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值