青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

天之道

享受編程的樂(lè)趣。
posts - 118, comments - 7, trackbacks - 0, articles - 0
  C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
二叉樹(shù)可以采用數(shù)組的方法進(jìn)行存儲(chǔ),把數(shù)組中的數(shù)據(jù)依次自上而下,自左至右存儲(chǔ)到二叉樹(shù)結(jié)點(diǎn)中,一般二叉樹(shù)與完全二叉樹(shù)對(duì)比,比完全二叉樹(shù)缺少的結(jié)點(diǎn)就在數(shù)組中用0來(lái)表示

結(jié)點(diǎn)存儲(chǔ)的數(shù)據(jù)均為非負(fù)整數(shù)

Input

第一行輸入一個(gè)整數(shù)t,表示有t個(gè)二叉樹(shù)

第二行起,每行輸入一個(gè)數(shù)組,先輸入數(shù)組長(zhǎng)度,再輸入數(shù)組內(nèi)數(shù)據(jù),每個(gè)數(shù)據(jù)之間用空格隔開(kāi),輸入的數(shù)據(jù)都是非負(fù)整數(shù)

連續(xù)輸入t行

Output

每行輸出一個(gè)示例的先序遍歷結(jié)果,每個(gè)結(jié)點(diǎn)之間用空格隔開(kāi)

Sample Input

3
3 1 2 3
5 1 2 3 0 4
13 1 2 3 4 0 5 6 7 8 0 0 9 10
Sample Output

1 2 3 
1 2 4 3 
1 2 4 7 8 3 5 9 10 6 

分析:
這道題的關(guān)鍵在于:設(shè)定數(shù)組位置從1開(kāi)始編號(hào),那么位置為i的結(jié)點(diǎn),它的左孩子在數(shù)組的位置是2i,右孩子在數(shù)組的位置是2i+1

這道題的難點(diǎn)在把樹(shù)建立起來(lái),其他都容易。

代碼:

#include <iostream> 
using namespace std;

class BiTreeNode
{

private:

 BiTreeNode  *leftChild;      //左子樹(shù)指針

 BiTreeNode  *rightChild;      //右子樹(shù)指針

public:

 int  data;           //數(shù)據(jù)域


 
//構(gòu)造函數(shù)和析構(gòu)函數(shù)

 BiTreeNode():leftChild(NULL), rightChild(NULL){}

 BiTreeNode(int  item, BiTreeNode  *left = NULL, 

    BiTreeNode  *right = NULL):

    data(item), leftChild(left), rightChild(right){}

 ~BiTreeNode(){}


 BiTreeNode  * &Left(void//注意返回值類(lèi)型為指針的引用類(lèi)型

  {return leftChild;}

 BiTreeNode  * &Right(void//注意返回值類(lèi)型為指針的引用類(lèi)型

  {return rightChild;}

};




class BiTree

{

private:

 BiTreeNode  *root;       //根結(jié)點(diǎn)指針

    int i,len; //len是樹(shù)結(jié)點(diǎn)的數(shù)量

 void Destroy(BiTreeNode  * &t);

 void PreOrder(BiTreeNode  * &t);

 void  CreateBiTree(BiTreeNode * &T,const int arrTree[],int pos);

public:

 //構(gòu)造函數(shù)和析構(gòu)函數(shù)

 BiTree(void):root(NULL),i(0){};     //構(gòu)造函數(shù)

 ~BiTree(void){};        //析構(gòu)函數(shù)


 
//構(gòu)造二叉樹(shù)

   void MakeTree(const int arrTree[],int num); //構(gòu)造二叉樹(shù),利用先序遍歷結(jié)果建樹(shù)

   void Destroy(void);        //銷(xiāo)毀二叉樹(shù)


 void PreOrder();  //前序遍歷 

};


//2、定義銷(xiāo)毀函數(shù)

void BiTree ::Destroy(void)       //銷(xiāo)毀二叉樹(shù),公有函數(shù)

{

 Destroy(root);

}


void BiTree ::Destroy(BiTreeNode  * &t)             

//銷(xiāo)毀二叉樹(shù),私有函數(shù)供共有函數(shù)調(diào)用

{

 if(t != NULL && t->Left() != NULL)

  Destroy(t->Left());


 if(t != NULL && t->Right() != NULL)

  Destroy(t->Right());


 if(t != NULL)

 {
  delete t;
 }

}


//3、定義建樹(shù)函數(shù)

void BiTree::MakeTree(const int arrTree[],int num)

//構(gòu)造二叉樹(shù),利用先序遍歷結(jié)果建樹(shù),公有函數(shù)

{

   i=0;
   len = num;

   CreateBiTree(root,arrTree,1);//數(shù)組位置從1開(kāi)始

}


void BiTree::CreateBiTree(BiTreeNode * &T, const int arrTree[],int pos)   //遞歸建樹(shù)私有函數(shù)

{

 int ch;

 ch=arrTree[pos]; 

 if (ch == 0 || pos > len) T = NULL;

 else 

 {

  T=new BiTreeNode();

  T->data = ch;              // 生成根結(jié)點(diǎn)
  i++;
  if(i>len) return;

  CreateBiTree(T->Left(), arrTree,2*pos);   // 構(gòu)造左子樹(shù)

  CreateBiTree(T->Right(), arrTree,2*pos+1);   // 構(gòu)造右子樹(shù)

   } 

}

//4、定義先序遍歷函數(shù)

void BiTree::PreOrder()

//前序遍歷訪問(wèn)二叉樹(shù),公有函數(shù)

{

 PreOrder(root);

}


void BiTree::PreOrder(BiTreeNode* &t)

//前序遍歷訪問(wèn)二叉樹(shù),私有函數(shù)t

{


  if(t!=NULL)//若二叉樹(shù)結(jié)點(diǎn)不為空,執(zhí)行如下操作:
  {
      cout<<t->data<<" ";//1、輸出當(dāng)前結(jié)點(diǎn)的數(shù)據(jù),表示該結(jié)點(diǎn)被訪問(wèn)了

      PreOrder(t->Left());//2、先序遍歷該結(jié)點(diǎn)的左孩子

      PreOrder(t->Right());//3、先序遍歷該結(jié)點(diǎn)的右孩子
  }


}

int main()
{
    int m,i,j,k;
    int *arrTree;
    BiTree myTree;
    cin>>m;
    for(i=0;i<m;i++)
    {
        arrTree = new int[800];
        cin>>k;
        for(j=1;j<=k;j++)
            cin>>arrTree[j];
        myTree.MakeTree(arrTree,k);
        myTree.PreOrder();
        cout<<endl;
        
        delete []arrTree;
        myTree.Destroy();
    }
    return 0;
}
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一区二区三| 欧美激情一区二区三级高清视频 | 亚洲一区免费| 亚洲激情影院| 欧美激情2020午夜免费观看| 久久久99爱| 久久福利资源站| 久久国产精品免费一区| 性欧美激情精品| 欧美一级二区| 久久免费偷拍视频| 裸体歌舞表演一区二区| 久久久一区二区三区| 久久综合色一综合色88| 欧美亚洲网站| 久久亚洲二区| 国产精品黄视频| 国产午夜亚洲精品理论片色戒| 久久露脸国产精品| 亚洲国产天堂久久综合网| 99这里只有久久精品视频| 亚洲香蕉伊综合在人在线视看| 午夜一级在线看亚洲| 日韩午夜剧场| 久久精品网址| 99re8这里有精品热视频免费 | 久久亚洲高清| 国产精品免费视频xxxx| 在线成人免费观看| 亚洲欧美日韩在线一区| 欧美国产一区二区| 欧美伊久线香蕉线新在线| 欧美日韩性视频在线| 亚洲国产欧美国产综合一区| 久久精品国产清高在天天线| 99精品免费| 国产精品国内视频| 亚洲一二三四区| av成人免费观看| 欧美三级电影网| 午夜精品99久久免费| 一区二区动漫| 国产精品白丝jk黑袜喷水| 一区二区三区四区五区精品| 亚洲人屁股眼子交8| 欧美精选午夜久久久乱码6080| 午夜精品成人在线视频| 国产精品久久二区| 欧美一级片一区| 久久精品视频导航| 亚洲人成精品久久久久| 亚洲日本欧美天堂| 欧美日韩xxxxx| 亚欧美中日韩视频| 久久精品国产77777蜜臀| 亚洲黄色成人| 亚洲一区黄色| 亚洲精品一区二区三| 亚洲视频一区在线观看| 国产一区二区三区自拍| 亚洲高清在线播放| 国产伦理一区| 亚洲日本在线观看| 国产精品女人毛片| 亚洲高清一区二| 一区二区三区中文在线观看| 亚洲欧洲在线播放| 在线精品亚洲| 欧美一区二区三区四区高清| 一区二区视频免费在线观看| 亚洲精品少妇网址| 韩国成人理伦片免费播放| 99精品国产在热久久下载| 国产麻豆一精品一av一免费| 亚洲国产另类久久精品| 国产精品久久久久一区二区三区共 | 亚洲国产精品成人一区二区| 国产精品一二三| 亚洲国产日韩欧美在线99| 日韩亚洲在线观看| 国产自产在线视频一区| 亚洲人成绝费网站色www| 国产资源精品在线观看| 欧美高清在线精品一区| 国产精品成人在线观看| 亚洲精品色婷婷福利天堂| 亚洲第一久久影院| 久久久噜噜噜久久| 另类春色校园亚洲| 国产一区二区三区在线观看视频 | 欧美日韩中文字幕在线| 欧美激情区在线播放| 在线成人h网| 久久大综合网| 久久精视频免费在线久久完整在线看| 国产精品国产三级国产aⅴ浪潮| 亚洲另类春色国产| 亚洲精品久久久久久下一站 | 亚洲大胆人体视频| 亚洲另类春色国产| 国产精品一区二区黑丝| 欧美一区亚洲一区| 欧美国产亚洲另类动漫| 亚洲性视频网站| 国产一区在线播放| 欧美黄色一区| 久久久久久自在自线| aⅴ色国产欧美| 亚洲福利视频二区| 性欧美在线看片a免费观看| 亚洲大片av| 国内精品久久久久影院 日本资源| 美女啪啪无遮挡免费久久网站| 国产精品99久久久久久人| 久久av免费一区| 亚洲精品一区二区三| 国语自产精品视频在线看抢先版结局 | 模特精品在线| 久久成年人视频| 在线视频你懂得一区二区三区| 久久久久99| 久久久久久一区二区| 午夜在线成人av| 午夜日韩电影| 欧美一级理论片| 欧美综合国产| 久久aⅴ国产紧身牛仔裤| 先锋影院在线亚洲| 亚洲欧美日韩另类| 亚洲在线视频观看| 亚洲欧美中文日韩在线| 欧美一区2区三区4区公司二百| 一本色道88久久加勒比精品| 99国产精品久久久久久久成人热| 日韩视频一区二区三区在线播放| 亚洲精品中文字幕女同| 亚洲精品视频中文字幕| 亚洲电影观看| 日韩视频永久免费| 欧美中文字幕在线视频| 狼狼综合久久久久综合网 | 久久国产日韩欧美| 欧美电影电视剧在线观看| 亚洲欧洲在线一区| 欧美高清在线播放| 亚洲免费播放| 香蕉成人久久| 欧美丰满少妇xxxbbb| 一区二区免费在线观看| 久久久蜜桃一区二区人| 欧美视频精品一区| 在线观看欧美日韩国产| 亚洲欧美电影在线观看| 久久免费精品视频| 亚洲伊人网站| 欧美日韩亚洲激情| 亚洲福利视频二区| 欧美成人免费小视频| 亚洲欧美在线另类| 国产精品久久久久久久9999 | 美国十次了思思久久精品导航| 国产精品成人久久久久| 亚洲欧洲日本mm| 亚洲激情在线观看| 免费av成人在线| 在线播放豆国产99亚洲| 欧美午夜宅男影院| 亚洲一区二区免费视频| 一区二区电影免费在线观看| 欧美日韩在线播放三区四区| 99热精品在线观看| 夜色激情一区二区| 国产精品区一区二区三区| 欧美一区二区三区免费视频| 午夜精品久久久久久99热| 国产拍揄自揄精品视频麻豆| 久久视频在线看| 免费看的黄色欧美网站| 亚洲一区视频在线| 久久国内精品视频| 亚洲激情偷拍| 亚洲综合精品一区二区| 在线播放日韩专区| 最新日韩精品| 国产在线观看91精品一区| 欧美激情一二区| av成人老司机| 韩国一区电影| 欧美一级理论片| 欧美va天堂va视频va在线| 久久精彩免费视频| 欧美私人网站| 亚洲精品日韩欧美| 亚洲性色视频| 国产精品色一区二区三区| 在线一区二区三区四区| 亚洲午夜精品一区二区| 美女性感视频久久久| 欧美成人一区二区三区在线观看| 国产一区二区三区黄|