给出先序,构建二叉排序树

思路:每来一个节点,都从头开始判断是属于左子树还是右子树,假如判断属于左子树,(然后再用左子树的根节点来判断属于左子树中的左子树还是右子树)----->适合用递归,直到走到叶子节点,再插入

用递归   str1 为先序

LinkTree *dd(LinkTree *r)
{
    return r;
}

LinkTree *CreateLinkTree(LinkTree *root,TElemType *str1,TElemType *str2)
{
    LinkTree *r = root;
    r ->data = *str1;
    str1++;
    while(*str1)
    {
        r = root;
        LinkTree *pnew = (LinkTree *)malloc(sizeof(LinkTree));
        pnew ->data = *str1;
        pnew ->lchild = pnew ->rchild = NULL;
        pnew ->num = pnew ->Same_Size = 0;
        while(1)
        {
            if(r ->data > *str1 && r ->lchild)
            {
                r = dd(r ->lchild);
                continue;
            }
            else if(r ->data > *str1 && !r ->lchild)
            {
                r ->lchild = pnew;
                break;
            }
            if(r ->data < *str1 && r ->rchild)
            {
                r = dd(r ->rchild);
            }
            else if(r ->data < *str1 && !r ->rchild)
            {
                r ->rchild = pnew;
                break;
            }
        }
    str1++;
    }
    return root;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值