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

天之道

享受編程的樂趣。
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人久久精品视频最新地址| 国产精品国产三级国产普通话99| 午夜精品福利在线观看| 亚洲一区二区影院| 久久精品观看| 欧美成年人网站| 欧美日韩国产三级| 国产情人节一区| 亚洲久色影视| 久久国产黑丝| 欧美成人性生活| 亚洲视频日本| 久久精品视频在线观看| 欧美黄色成人网| 一区二区三区国产| 国产一区二区三区在线观看免费| 激情综合色综合久久综合| 亚洲欧美日韩爽爽影院| 欧美成人精品三级在线观看| 欧美电影美腿模特1979在线看| 欧美xxx在线观看| 国产麻豆午夜三级精品| 一区三区视频| 亚洲成人在线视频播放 | 久久久久久亚洲精品杨幂换脸| 午夜亚洲福利在线老司机| 亚洲高清精品中出| 免费视频亚洲| 久久久高清一区二区三区| 中文亚洲免费| 久久人体大胆视频| 欧美成人影音| 一区二区电影免费在线观看| 亚洲一区区二区| 亚洲欧美日本视频在线观看| 午夜精品免费| 久久久精品免费视频| 国产综合色在线| 欧美黄色大片网站| 亚洲国产成人在线| 欧美影片第一页| 日韩一级黄色av| 翔田千里一区二区| 狂野欧美激情性xxxx| 亚洲美女精品成人在线视频| 欧美一区二区三区在线免费观看| 久久精品99国产精品日本| 亚洲高清自拍| 欧美h视频在线| 国产色产综合色产在线视频| 午夜在线一区二区| 9色精品在线| 欧美性做爰毛片| 一个色综合导航| 亚洲最新视频在线播放| 99热免费精品在线观看| 国产偷国产偷亚洲高清97cao| 亚洲在线视频免费观看| 久久aⅴ国产欧美74aaa| 亚洲欧洲精品一区二区三区不卡 | 日韩天堂av| 欧美精品免费观看二区| 亚洲午夜av在线| 久久狠狠久久综合桃花| 亚洲国产成人精品女人久久久| 欧美在线视频免费播放| 久久精品一区二区三区不卡牛牛| 亚洲日本中文字幕区| 亚洲成色999久久网站| 91久久国产精品91久久性色| 国产精品vvv| 噜噜噜久久亚洲精品国产品小说| 欧美福利一区二区三区| 久色婷婷小香蕉久久| 国产精品v欧美精品v日本精品动漫| 欧美大片一区二区| 久久久久久久精| 国产一区二区成人| 亚洲视频电影图片偷拍一区| 一本久道久久久| 欧美国产精品人人做人人爱| 狂野欧美激情性xxxx| 国产综合一区二区| 亚洲乱码国产乱码精品精天堂 | 国产精品成人一区二区| 亚洲人成网站777色婷婷| 精品动漫3d一区二区三区| 亚洲天堂av高清| 中文日韩在线| 国产欧美一区二区精品忘忧草 | 麻豆成人在线播放| 一本色道婷婷久久欧美| 欧美日韩成人一区二区| 日韩系列在线| 午夜精品免费| 黄色成人在线观看| 欧美精品综合| 午夜久久一区| 亚洲国产你懂的| 亚洲第一黄色网| 欧美日韩和欧美的一区二区| 亚洲精选一区| 久久综合色8888| 亚洲人午夜精品| 国产日韩欧美中文| 牛人盗摄一区二区三区视频| 亚洲国产精品欧美一二99| 亚洲欧美日韩精品久久| 国产一区二区毛片| 欧美日韩视频在线一区二区观看视频| 亚洲一区精彩视频| 欧美日韩在线播放三区四区| 欧美一级黄色录像| 亚洲视频电影在线| 日韩一级裸体免费视频| 欧美mv日韩mv国产网站app| 久久精彩免费视频| 午夜亚洲激情| 久久欧美肥婆一二区| 亚洲另类视频| 极品尤物av久久免费看| 欧美午夜大胆人体| 欧美va天堂| 欧美jjzz| 翔田千里一区二区| 亚洲国产精品久久91精品| 欧美日本韩国| 欧美日韩国产一区二区| 欧美精品免费视频| 欧美激情女人20p| 欧美片第1页综合| 欧美一区二区精品| 亚洲一级影院| 亚洲一区自拍| 久久成人免费| 国产一区二区三区在线观看免费 | 午夜电影亚洲| 欧美不卡一卡二卡免费版| 久久伊人亚洲| 国产一区二区三区四区三区四| 亚洲无线一线二线三线区别av| 亚洲精品综合| 欧美凹凸一区二区三区视频| 亚洲第一伊人| 亚洲国产经典视频| 久久一二三区| 欧美第十八页| 99热在这里有精品免费| 欧美激情久久久久| 99香蕉国产精品偷在线观看| 亚洲综合国产| 国产一二三精品| 久久婷婷av| 亚洲精品护士| 午夜精品成人在线| 激情国产一区| 欧美精品v日韩精品v韩国精品v| 亚洲黄色免费电影| 亚洲理伦在线| 国产精品美女一区二区在线观看| 亚洲免费一级电影| 老牛影视一区二区三区| 国产一区二区你懂的| 另类激情亚洲| 99成人免费视频| 久久久国产午夜精品| 亚洲区一区二| 欧美视频网站| 久久久欧美一区二区| 亚洲免费观看视频| 久久精视频免费在线久久完整在线看| 精品二区视频| 欧美日韩国产首页| 久久精品女人的天堂av| 亚洲精品激情| 99精品视频免费| 精品91在线| 欧美日韩高清一区| 午夜日本精品| 亚洲黄一区二区| 久久久91精品国产一区二区精品| 亚洲区一区二区三区| 国产精品久久久久久久7电影| 久久久久久91香蕉国产| 99精品欧美一区| 欧美电影免费观看高清完整版| 亚洲一区二区三区在线播放| 亚洲国产乱码最新视频| 国产精品女主播| 欧美日韩精品| 免费影视亚洲| 久久国产精品99久久久久久老狼 | 99精品热6080yy久久 |