首页 > 其他 > 详细

普通二叉树转换成搜索二叉树

时间:2014-08-27 23:10:48      阅读:319      评论:0      收藏:0      [点我收藏+]
struct ListNode
{
    int data;
    ListNode *lchild,*rchild;
};

void CreateBSTree(ListNode *B2_root,ListNode *BSTree_root)
{
     if(BSTree_root==NULL)
     {
         BSTree_root = (ListNode*)malloc(sizeof(ListNode));
         BSTree_root->lchild=BSTree_root->rchild=NULL;
         BSTree_root->data=B2_root->data;
         return ;
     }
     if(B2_root->data<BSTree_root->data) CreateBSTree(B2_root,BSTree_root->lchild);
     if(B2_root->data>BSTree_root->data) CreateBSTree(B2_root,BSTree_root->rchild);
}

void PreOrder(ListNode *B2_root,ListNode *BSTree_root)
{
     if(B2_root==NULL) return ;//根节点就为空
     CreateBSTree(B2_root,BSTree_root);
     if(B2_root->lchild!=NULL) PreOrder(B2_root->lchild,BSTree_root);
     if(B2_root->rchild!=NULL) PreOrder(B2_root->rchild,BSTree_root);
}

ListNode* CreateBSTree(ListNode* B2_root)
{
    ListNode* BSTree_root=NULL;
    PreOrder(B2_root,BSTree_root);
    return BSTree_root;
}

  

普通二叉树转换成搜索二叉树

原文:http://www.cnblogs.com/zsboy/p/3940423.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!