创建二叉树算法

根据括号次序创建二叉树,字符串如char Stra[30]="A(B(D(,G)),C(E,F))";

基本思路:

如果是非(,),则创建一个节点(对于书为空时,将其设为根节点,非空时,如果其前一个字符时(,则讲其插入前一个字符的左孩子中,如果是,,插入右孩子中。)。

对于"(",","可以忽略字符,但保留标记,以用于下一个字符的插入。")"标志着当前栈节点左右孩子都插满了,所以可将其产出。

具体代码如下(PAGES201):

#include <stdio.h>
#include <stdlib.h>
const int MaxSize=40;
struct BTNode
{
    char date;
    BTNode* Leftchild;
    BTNode* Rightchild;
};
void createBTNode(BTNode *&b, char *str)
{
    BTNode *St[MaxSize];int top=-1;
    int j=0;
    b=NULL;
    BTNode *p=NULL;
    char ch=str[j];
    int k=0;
    while(ch!='\0')
    {
        switch (ch)
        {
        case '(':
            top++;St[top]=p; k=1;break;    
        case ',':
            k=2;break;
        case ')':
            top--;break;
        default:
            p=(BTNode*)malloc(sizeof(BTNode));
            p->Leftchild=NULL;p->Rightchild=NULL;p->date=ch;
            if (b==NULL)
            {
                b=p;
            }
            else 
                switch (k)
            {
                case 1:
                    St[top]->Leftchild=p;break;
                case 2:
                    St[top]->Rightchild=p;break;
            }
        }
        ch=str[++j];
    }

}
void PREOrder(BTNode* T)
{
    if (T!=NULL)
    {
        printf("%c\n",T->date);
        PREOrder(T->Leftchild);        
        PREOrder(T->Rightchild);
    }
}
int main()
{

    char Stra[30]="A(B(D(,G)),C(E,F))";
    BTNode *Root;
    createBTNode(Root,Stra);
    PREOrder(Root);
}

 

 

转载于:https://www.cnblogs.com/lisongfeng9213/p/3426007.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值