zoukankan      html  css  js  c++  java
  • 层序创建二叉树

    创建过程:

    (1) 输入第一个数据:

     若为0,表示此树为空,将空指针赋给根指针,树构造完毕;

     若不为0,动态分配一个节点单元,并存入数据,同时将该节点地址放入队列。

    (2) 若节点不为空,从队列中取出一个节点地址,并建立该节点的左右孩子:

     从输入序列中读入下一数据;

     若读入的数据为0,将出队节点的左孩子指针置空;否则,分配一个新的节点单元,存入所读值,并将其置为出队节点的左孩子,同时将此孩子地址入队;

     接着再从输入序列中读入下一个数据;

     若读入的数据为0,将出队节点的右孩子指针置空;否则,分配一个新的节点单元,存入所读值,并将其置为出队节点的右孩子,同时将此孩子地址入队;

    (3) 重复第(2)步过程,直到队列为空,再无节点出队,构造过程到此结束。

    typedef int ElementType;
    #define NoInfo 0   //用0表示没有节点
    
    //层序创建二叉树
    BinTree CreateBinTree()
    {
        ElementType Data;
        BinTree BT, T;
        queue<TNode *> Q;
        
        //创建第1个节点,即根节点
        cin >> Data;
        if(Data != NoInfo)
        {
            //分配节点单元,并将节点地址入队
            BT = (BinTree)malloc(sizeof(struct TNode));
            BT->Data = Data;
            BT->Left = BT->Right = NULL;
            Q.push(BT);
        }
        else
            return NULL;  //若第一个数据就是0,返回空树
        
        while(!Q.empty())
        {
            T = Q.front(); //从队列中取出一节点地址
            Q.pop();
            cin >> Data;   //读入T的左孩子
            if(Data == NoInfo)
                T->Left = NULL;
            else
            {
                //分配新节点,作为出队节点的左孩子,并将该新节点入队
                T->Left = (BinTree)malloc(sizeof(struct TNode));
                T->Left->Data = Data;
                T->Left->Left = T->Left->Right = NULL;
                Q.push(T->Left);
            }
            
            cin >> Data;  //读入T的右孩子
            if(Data == NoInfo)
                T->Right = NULL;
            else
            {
                //分配新节点,作为出队节点的右孩子,并将该新节点入队
                T->Right = (BinTree)malloc(sizeof(struct TNode));
                T->Right->Data = Data;
                T->Right->Left = T->Right->Right = NULL;
                Q.push(T->Right);
            }
        } //结束while
        
        return BT;    //返回二叉树的根节点
    }
  • 相关阅读:
    爬虫 比较好的视频推荐
    Scrapy爬取某装修网站部分装修效果图
    scrapy爬取阳光电影网全站资源
    爬虫练手实例
    Scrapy框架详解
    淘宝商品信息定向爬虫实例介绍
    Python基础第20天
    Python基础第19天
    Python基础第18天
    Python基础第17天
  • 原文地址:https://www.cnblogs.com/FengZeng666/p/9729818.html
Copyright © 2011-2022 走看看