先序创建二叉树

//定义二叉树结构

typedef struct BiTreeNode{

    char data;        //结点存放的数据

    BiTreeNode *lchild, *rchild;        //树的左结点右结点指针

}BiTreeNode, *BiTree;                //BiTreeNode为结构体,BiTree为指向这个结构体的指针

void CreateBiTree(BiTree &T)            //创建二叉树

{

    char ch;        //创建变量ch

    scanf("%c\n",&ch);        //把标准输入流(键盘输入),回车后,把字符存入ch地址中;

    if( ch == "#")  T == NULL;

    else

    {

        T = (BiTreeNode *)malloc(sizeof(BiTreeNode));        //T指向新创建的结点

        if (T == NULL) return;         //如果T为空,说明结点创建失败

        T->data = ch;                        //给T赋值

        CreateBiTree(T->lchild);        //先递归创建左子树

        CreateBiTree(T->rchild);        //再递归创建右子树

    } 

}

int main()        //调用函数

{

    BiTree = NULL;         //初始化一棵树

    CreateBiTree(T);

}

  • 6
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值