数据结构——树的实现

在做树的遍历的时候发现自己对实现树的方法不太了解,也就是不知道怎么把一棵树的结构存到内存中,所以对树的实现找了一些资料,自己也研究了一下。

首先,要想让计算机正确的保存你的“树”,你要用一种和你代码相匹配的输入方式,我用的是采用广义表表示的输入法,例如:A(B(D,E),C(F,G))。
这个式子可以分为以下几部分:
A(B,C): A是这个结构的根节点,B,C是A的两个孩子。
A(B(D,E),C(F,G)):B,C分别是D、E和F、G的父节点。

              A
            /   \
           B     C
          / \   / \
         D   E F   G

当用广义表表示的方法输入之后,就可以用下面的代码来建立二叉树:

void CreateBTree(struct BTreeNode** BT, char* string)
{
    struct BTreeNode* p;
    struct BTreeNode* s[StackMaxSize];   //定义s数组作为存储根结点的指针的栈使用
    int top = -1;               //栈顶指针置为-1,表示空栈
    int k;                 //k作为处理结点的标志,k=1处理左子树,k=2处理右子树
    int i = 0;              //用i扫描数组string中存储的二叉树广义表字符串,初值为0
    *BT = NULL;               //把树根指针置空,即从空树开始建立二叉树
    while (string[i])
    {
        switch (string[i])
        {
            case ' ':break;
            case '(':
            {
                if (top == StackMaxSize - 1)
                {
                    printf("栈空间太小,需增加StackMaxSize!\n");
                    exit(1);
                }
                top++;
                s[top] = p;
                k = 1;
                break;
            }
            case ')':
            {
                if (top == -1)
                {
                    printf("二叉树广义表字符串错!\n");
                    exit(1);
                }
                top--;
                break;
            }
            case ',':k = 2;break;
            default:
            {
                p = malloc(sizeof(struct BTreeNode));
                p->data = string[i];
                p->left = p->right = NULL;
                if (*BT == NULL)
                    *BT = p;
                else
                {
                    if (k == 1)
                        s[top]->left = p;
                    else
                        s[top]->right = p;
                }
            }
        }
        i++;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值