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

天之道

享受編程的樂趣。
posts - 118, comments - 7, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

二叉樹之父子結點

Posted on 2012-10-16 23:54 hoshelly 閱讀(1005) 評論(0)  編輯 收藏 引用
給定一顆二叉樹的邏輯結構如下圖,(先序遍歷的結果,空樹用字符‘0’表示,例如AB0C00D00),建立該二叉樹的二叉鏈式存儲結構。

編寫程序輸出該樹的所有葉子結點和它們的父親結點



Input

第一行輸入一個整數t,表示有t個二叉樹

第二行起,按照題目表示的輸入方法,輸入每個二叉樹的先序遍歷,連續輸入t行

Output

第一行按先序遍歷,輸出第1個示例的葉子節點

第二行輸出第1個示例中與葉子相對應的父親節點

以此類推輸出其它示例的結果

 

Sample Input

3
AB0C00D00
AB00C00
ABCD0000EF000
Sample Output

C D 
B A 
B C 
A A 
D F 
C E 


代碼:

#include <iostream> 
using namespace std;

class BiTreeNode

{

private:

 BiTreeNode  *leftChild;      //左子樹指針

 BiTreeNode  *rightChild;      //右子樹指針

public:

 char  data;           //數據域
 char  father;


 //構造函數和析構函數

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

 BiTreeNode(char  item, char  father, BiTreeNode  *left = NULL, 

    BiTreeNode  *right = NULL):

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

 ~BiTreeNode(){}


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

  {return leftChild;}

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

  {return rightChild;}
};




class BiTree

{

private:

 BiTreeNode  *root;       //根結點指針

    int i; 

 void Destroy(BiTreeNode  * &t);
 
 void PreLeave(BiTreeNode  * &t);

 void Prefather(BiTreeNode  * &t);

 void CreateBiTree(BiTreeNode * &T,const char strTree[],char father);

public:

 //構造函數和析構函數

 BiTree(void):root(NULL),i(0){};     //構造函數

 ~BiTree(void){};        //析構函數


 
//構造二叉樹

   void MakeTree(const char item,char father, BiTree  &left, BiTree  &right); //構造二叉樹

   void MakeTree(const char strTree[]); //構造二叉樹,利用先序遍歷結果建樹

   void Destroy(void);        //銷毀二叉樹


 void PreLeave();  //前序遍歷 
 
 void Prefather();

};

//2、定義銷毀函數

void BiTree ::Destroy(void)       //銷毀二叉樹,公有函數

{

 Destroy(root);

}


void BiTree ::Destroy(BiTreeNode  * &t)             

//銷毀二叉樹,私有函數供共有函數調用

{

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

  Destroy(t->Left());


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

  Destroy(t->Right());


 if(t != NULL)

 {

 // cout << t->data << "   ";    //此語句只是為了方便測試

  delete t;

 }

}


//3、定義建樹函數

void BiTree::MakeTree(const char item, char father,BiTree  &left, BiTree  &right)

//構造數據域為item,左子樹為left,右子樹為right的二叉樹

{

 root = new BiTreeNode(item,father, left.root, right.root);

}


void BiTree::MakeTree(const char strTree[])

//構造二叉樹,利用先序遍歷結果建樹,公有函數

{

   i=0;
   char rootfather = '0';
   CreateBiTree(root,strTree,rootfather);

}


void BiTree::CreateBiTree(BiTreeNode * &T, const char strTree[],char father)   //遞歸建樹私有函數

{

 char ch;

 ch=strTree[i++];

    if (ch=='0') T = NULL;

 else 

 {

  T=new BiTreeNode();

  T->data = ch;              // 生成根結點
  T->father = father;
  
  father = ch;

  CreateBiTree(T->Left(), strTree,father);   // 構造左子樹

  CreateBiTree(T->Right(), strTree,father);   // 構造右子樹

 } 

}

//4、定義先序遍歷函數

void BiTree::PreLeave()

//前序遍歷訪問二叉樹,公有函數

{

 PreLeave(root);

}


void BiTree::PreLeave(BiTreeNode* &t)

//前序遍歷訪問二叉樹,私有函數t

{


  if(t)//若二叉樹結點不為空,執行如下操作:
  {
      if(!t->Left() && !t->Right()) //如果當前結點是葉子
          cout<<t->data<<" ";
      PreLeave(t->Left());//2、先序遍歷該結點的左孩子

      PreLeave(t->Right());//3、先序遍歷該結點的右孩子
  }


}


//5、定義遍歷父節點函數

void BiTree::Prefather()

{

 Prefather(root);

}


void BiTree:: Prefather(BiTreeNode* &t)

//中序遍歷訪問二叉樹,私有函數t

{


   if(t)//若二叉樹結點不為空,執行如下操作:
   {
       if(!t->Left() && !t->Right())//如果當前結點是葉子,輸出它的父親
           cout<<t->father<<" ";
       Prefather(t->Left());
       Prefather(t->Right());

   }


}


int main(void)

{

 int n,i;

 char strTree[800];

 BiTree myTree;

 cin>>n;

 cin.get();

    for(i=0;i<n;i++)

 {

  cin>>strTree;

  myTree.MakeTree(strTree);

  myTree.PreLeave();

  cout<<endl;

  myTree.Prefather();

  cout<<endl;

  myTree.Destroy();

 }

 return 0;


}

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品国产精品乱码不99| 久久综合久久久久88| 欧美午夜不卡视频| 欧美刺激性大交免费视频| 亚洲在线视频网站| 国产一区香蕉久久| 激情亚洲网站| 亚洲黄色有码视频| 亚洲另类在线视频| 亚洲一区免费网站| 久久精品国产亚洲一区二区| 久久综合图片| 亚洲日本中文字幕| 欧美国产日韩一区二区| 一本色道**综合亚洲精品蜜桃冫 | 欧美丰满少妇xxxbbb| 欧美私人啪啪vps| 国产一二三精品| 日韩一级视频免费观看在线| 亚洲欧美一区二区视频| 免费在线观看精品| 亚洲免费人成在线视频观看| 久久久777| 国产精品女人网站| 亚洲狼人综合| 免费在线看一区| 午夜久久久久久| 能在线观看的日韩av| 国内成+人亚洲| 久久精品亚洲精品国产欧美kt∨| 亚洲激情图片小说视频| 久久精品国产在热久久| 国产欧美亚洲精品| 午夜精品久久久久久99热| 日韩亚洲欧美综合| 欧美激情综合五月色丁香| 亚洲国产精品一区在线观看不卡| 久久久精品免费视频| 一本色道久久88综合亚洲精品ⅰ| 久久一区二区精品| 久久精品国产免费看久久精品| 国产性做久久久久久| 久久免费精品视频| 欧美成人午夜激情视频| 99精品视频一区| 国产真实久久| 亚洲国产精品福利| 欧美日韩综合久久| 久久亚裔精品欧美| 欧美黄免费看| 欧美一区二区黄色| 久久久综合视频| 亚洲中字在线| 久久美女艺术照精彩视频福利播放| 亚洲狠狠婷婷| 欧美一区二区三区另类| av成人免费在线观看| 久久aⅴ国产欧美74aaa| 亚洲日韩欧美视频| 久久成人18免费网站| 亚洲在线1234| 欧美国产一区视频在线观看| 久久国产夜色精品鲁鲁99| 欧美国产在线观看| 噜噜噜噜噜久久久久久91| 国产精品一区亚洲| 艳妇臀荡乳欲伦亚洲一区| 亚洲国产欧美一区二区三区丁香婷| 亚洲一级二级| 欧美一区影院| 欧美丝袜一区二区三区| 一区二区三区欧美视频| 在线视频精品一| 欧美日韩国产一级| 欧美性大战久久久久| 欧美91精品| 免费一级欧美片在线观看| 国产精品网站在线观看| 在线亚洲国产精品网站| 一区二区三区久久久| 欧美久久久久中文字幕| 亚洲激情在线播放| 亚洲精品影院在线观看| 欧美日韩精品| 亚洲综合色自拍一区| 欧美一区二区三区四区高清| 国产精品视频福利| 欧美一区二区三区久久精品茉莉花 | 精品动漫3d一区二区三区| 亚洲欧美日本国产有色| 久久久亚洲人| 一级成人国产| 国产欧美日韩精品一区| 欧美电影美腿模特1979在线看| 91久久久久久久久| 亚洲图片欧美午夜| 亚洲动漫精品| 国产欧美日韩一区| 欧美日韩成人在线观看| 久久精品卡一| 亚洲欧美日韩国产综合在线| 欧美激情亚洲精品| 久久久久国产精品一区二区| 99ri日韩精品视频| 国产一区欧美日韩| 国产精品欧美精品| 欧美日本在线一区| 久久免费精品视频| 久久精品人人做人人爽| 亚洲五月婷婷| 国产日韩欧美成人| 国产精品福利在线| 欧美日韩国产一中文字不卡| 久久亚洲精品中文字幕冲田杏梨| 亚洲免费视频观看| 午夜精品久久久久久99热软件| 91久久嫩草影院一区二区| 免费视频亚洲| 亚洲电影免费观看高清| 欧美国产成人精品| 亚洲欧洲精品一区二区| 欧美黑人在线播放| 亚洲国产精品久久久久婷婷884 | 久久av一区二区三区| 99re亚洲国产精品| 亚洲一区日韩在线| 午夜精品久久| 久久免费视频在线| 欧美激情一区二区三区在线视频观看 | 米奇777在线欧美播放| 亚洲天堂av图片| 久久裸体视频| 亚洲精品色婷婷福利天堂| 亚洲一区二区三区视频| 久久国产精品一区二区三区| 欧美电影免费观看大全| 国产亚洲综合在线| 日韩一区二区精品在线观看| 欧美在线免费观看亚洲| 亚洲精品系列| 免费在线欧美黄色| 亚洲视频一区二区在线观看| 久久久久久久久综合| 国产精品99免视看9| 尤物精品在线| 玖玖精品视频| 欧美一区日本一区韩国一区| 欧美日韩一区二区三区四区在线观看| 国产欧美精品久久| 亚洲一区二区三区免费观看 | 激情视频一区二区三区| 亚洲男人av电影| 亚洲视频在线观看三级| 欧美日韩成人在线观看| 亚洲免费黄色| 最新高清无码专区| 开元免费观看欧美电视剧网站| 国产一区日韩欧美| 久久精品国产久精国产思思 | 亚洲少妇自拍| 9久re热视频在线精品| 欧美日韩美女在线观看| 亚洲一二三区在线观看| 亚洲专区一区| 黄色一区二区在线观看| 欧美福利专区| 欧美网站大全在线观看| 久久久国产精品一区二区三区| 久久av二区| 亚洲一区二区伦理| 欧美一区二区视频免费观看| 在线免费日韩片| 亚洲最新中文字幕| 亚洲国产女人aaa毛片在线| 亚洲美女尤物影院| 最新国产精品拍自在线播放| 亚洲自拍电影| 亚洲精选在线| 久久久综合免费视频| 午夜久久一区| 欧美日韩系列| 亚洲黄色在线看| 欧美专区在线观看| 亚洲综合视频1区| 免费91麻豆精品国产自产在线观看| 亚洲自拍偷拍视频| 欧美韩国日本一区| 欧美不卡高清| 亚洲福利视频网| 久久乐国产精品| 老司机免费视频一区二区| 国产欧美精品一区| 亚洲在线视频观看| 欧美一进一出视频| 国产视频欧美| 久久久久久久综合狠狠综合| 久久久噜噜噜久久中文字幕色伊伊| 国产女人18毛片水18精品| 亚洲欧美日韩精品久久久久| 欧美伊人久久久久久午夜久久久久 |