亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? treeiter.h

?? 清華大學(xué)版數(shù)據(jù)結(jié)構(gòu)的一下試題資料
?? H
字號:
#include <bintree.h>
#include <stack.h>
#include <queue.h>
#include <process.h>

template <class Type> class TreeIterator{
  public:
    TreeIterator(const BinaryTree<Type> & BT):T(BT),current(NULL){}
    virtual ~TreeIterator(){}
    virtual void First()=0;
    virtual void operator ++ ()=0;
    int operator + () const {return current!=NULL;}
    const Type  operator()()const;
  protected:
    const BinaryTree<Type>  T;
    const BinTreeNode<Type> * current;
  private:
    TreeIterator(const TreeIterator<Type> & ){}
    const TreeIterator<Type> & operator = (const TreeIterator<Type> &);
    };

  template<class Type> const Type  TreeIterator<Type>::operator()()const{
    if(current==NULL){
      cerr<<"Illegal access"<<endl;
      exit(1);
      }
    return current->GetData();
    }

template <class Type> struct stkNode{
  const BinTreeNode<Type> * Node;
  int PopTim;
  stkNode(const BinTreeNode<Type> * N=NULL):Node(N),PopTim(0){}
  };

template <class Type> class PostOrder:public TreeIterator<Type>{
  public:
    PostOrder(const BinaryTree<Type> & BT);
    ~PostOrder(){}
    void First();
    void operator ++();
  protected:
    Stack <stkNode<Type> > st;
    };

  template <class Type> PostOrder<Type>::PostOrder(const BinaryTree<Type> & BT):
	TreeIterator<Type>(BT){
    st.Push(stkNode<Type>(BT.GetRoot()));
    }

  template <class Type> void PostOrder<Type>::First(){
    st.MakeEmpty();
    if(T.GetRoot()!=NULL) st.Push(stkNode<Type> (T.GetRoot()));
    operator ++();
    }

  template <class Type> void PostOrder<Type>::operator ++(){
    if(st.IsEmpty()){
      if(current==NULL){
	cerr<<"Advanced past end"<<endl;
	exit(1);
	}
      current=NULL;
      return;
      }
    stkNode<Type> Cnode;
    for(;;){
      Cnode=st.Pop();
      if(++Cnode.PopTim==3){
	current=Cnode.Node;
	return;
	}
      st.Push(Cnode);
      if(Cnode.PopTim==1){
	if(Cnode.Node->GetLeft()!=NULL)
	  st.Push(stkNode<Type> (Cnode.Node->GetLeft()));
	  }
	  else{
	    if(Cnode.Node->GetRight()!=NULL)
	      st.Push(stkNode<Type> (Cnode.Node->GetRight()));
	      }
	    }
	  }

template<class Type> class InOrder:public PostOrder<Type>{
  public:
    InOrder(BinaryTree<Type> & BT):PostOrder<Type> (BT){}
    void First();
    void operator ++();
    };


  template<class Type> void InOrder<Type>::First(){
    st.MakeEmpty();
    if(T.GetRoot()!=NULL) st.Push(stkNode<Type>(T.GetRoot()));
    operator ++();
    }

  template <class Type> void InOrder<Type>::operator ++(){
    if(st.IsEmpty()){
      if(current==NULL){
	cerr<<"Advanced past end"<<endl;
	exit(1);
	}
      current=NULL;
      return;
    }
    stkNode<Type> Cnode;
    for(;;){
      Cnode=st.Pop();
      if(++Cnode.PopTim==2){
	current=Cnode.Node;
	if(Cnode.Node->GetRight()!=NULL)
	  st.Push(stkNode<Type>(Cnode.Node->GetRight()));
	return;
	}
      st.Push(Cnode);
      if(Cnode.Node->GetLeft()!=NULL)
	st.Push(stkNode<Type>(Cnode.Node->GetLeft()));
      }
    }


template <class Type> class PreOrder:public TreeIterator<Type>{
  public:
    PreOrder(const BinaryTree<Type> & BT);
    ~PreOrder(){}
    void First();
    void operator ++();
  protected:
    Stack<const BinTreeNode<Type> * > st;
    };

  template <class Type> PreOrder<Type>::PreOrder(const BinaryTree<Type> & BT):
    TreeIterator<Type>(BT){
      st.Push(BT.GetRoot());
      }

  template <class Type> void PreOrder<Type>::First(){
    st.MakeEmpty();
    if(T.GetRoot())st.Push(T.GetRoot());
    operator ++();
    }

  template <class Type> void PreOrder<Type>::operator ++(){
    if(st.IsEmpty()){
      if(current==NULL){
	cerr<<"Advanced past end"<<endl;
	exit(1);
	}
      current=NULL;
      return;
      }
    current=st.Pop();
    if(current->GetRight()!=NULL) st.Push(current->GetRight());
    if(current->GetLeft()!=NULL) st.Push(current->GetLeft());
    return;
    }

template <class Type> class LevelOrder:public TreeIterator<Type>{
  public:
    LevelOrder(const BinaryTree<Type> & BT);
    ~LevelOrder(){}
    void First();
    void operator ++();
  protected:
    Queue<const BinTreeNode<Type> * > qu;
    };

  template <class Type> LevelOrder<Type>::LevelOrder(const BinaryTree<Type> & BT):
    TreeIterator<Type>(BT){qu.EnQueue(BT.GetRoot());}


  template <class Type> void LevelOrder<Type>::First(){
    qu.MakeEmpty();
    if(T.GetRoot()) qu.EnQueue(T.GetRoot());
    operator ++();
    }

  template <class Type> void LevelOrder<Type>::operator ++(){
    if(qu.IsEmpty()){
      if(current==NULL){
	cerr<<"Advanced past end"<<endl;
	exit(1);
	}
      current=NULL;
      return;
      }
    current=qu.DeQueue();
    if(current->GetLeft()!=NULL) qu.EnQueue(current->GetLeft());
    if(current->GetRight()!=NULL) qu.EnQueue(current->GetRight());
    }



void main(){
  BinaryTree<int> bt;
  cin>>bt;
  PostOrder<int> btpostorder(bt);
  btpostorder.First();
  cout<<"now,postorder:\n";
  while(+btpostorder){
    cout<<btpostorder()<<' ';
    ++btpostorder;
    }
  cout<<endl;
  InOrder<int> btinorder(bt);
  btinorder.First();
  cout<<"now,inorder:\n";
  while(+btinorder){
    cout<<btinorder()<<' ';
    ++btinorder;
    }
  cout<<endl;
  PreOrder<int> btpreorder(bt);
  btpreorder.First();
  cout<<"now,preorder:\n";
  while(+btpreorder){
    cout<<btpreorder()<<' ';
    ++btpreorder;
    }
  cout<<endl;
  LevelOrder<int> btlevelorder(bt);
  btlevelorder.First();
  cout<<"now,levelorder:\n";
  while(+btlevelorder){
    cout<<btlevelorder()<<' ';
    ++btlevelorder;
    }
  cout<<endl;
  }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区精品久久911| 中文字幕成人av| 国产午夜精品福利| 一区二区三区四区五区视频在线观看| 亚洲成人你懂的| 国产成人午夜电影网| 欧美色图免费看| 国产精品系列在线| 免费一级欧美片在线观看| 9l国产精品久久久久麻豆| 精品久久一二三区| 亚洲综合成人在线| www.99精品| 国产视频在线观看一区二区三区| 午夜精品成人在线| 色婷婷激情综合| 中文字幕免费观看一区| 精油按摩中文字幕久久| 欧美撒尿777hd撒尿| 中文字幕在线一区| 国产精品一二三区| 欧美一区日本一区韩国一区| 亚洲自拍偷拍麻豆| 91小视频在线观看| 国产精品女主播在线观看| 国产一区欧美二区| 欧美大片拔萝卜| 六月丁香综合在线视频| 555夜色666亚洲国产免| 午夜成人免费电影| 欧美日韩三级一区| 亚洲午夜一区二区三区| 欧美主播一区二区三区| 一区二区三区四区不卡在线 | 精品久久久久99| 国产精品一色哟哟哟| 日韩一区二区三区免费观看| 亚洲不卡在线观看| 欧美一卡二卡三卡四卡| 蜜臀a∨国产成人精品| 在线成人小视频| 日韩国产精品91| 日韩欧美高清在线| 韩日欧美一区二区三区| 久久久一区二区三区| 国产一区不卡视频| 国产嫩草影院久久久久| 国产69精品一区二区亚洲孕妇| 国产午夜精品福利| jlzzjlzz欧美大全| 亚洲精品视频一区二区| 欧美在线观看视频一区二区三区| 亚洲国产cao| 日韩欧美国产系列| 国产成人综合亚洲91猫咪| 欧美激情在线看| 色婷婷综合中文久久一本| 亚洲无人区一区| 日韩一级大片在线观看| 国产91丝袜在线播放0| 国产精品情趣视频| 欧美精品乱码久久久久久| 久久精品久久综合| 国产日本欧美一区二区| 91啦中文在线观看| 男女视频一区二区| 国产精品对白交换视频 | 欧洲av在线精品| 久久国产精品色| 国产精品高潮呻吟| 精品视频一区二区三区免费| 久久99这里只有精品| 国产精品精品国产色婷婷| 欧美日韩电影在线| 成人黄色大片在线观看| 亚洲福利视频一区| 中文字幕av一区 二区| 欧美日韩亚洲另类| 国产成人免费av在线| 亚洲高清不卡在线观看| 国产三区在线成人av| 欧美日韩国产高清一区二区三区| 国产一区二区三区黄视频 | 天天射综合影视| 亚洲国产精品t66y| 日韩一区二区影院| 国产午夜亚洲精品不卡| 欧美疯狂做受xxxx富婆| 99久久99久久综合| 久久精品国产网站| 一区二区三区在线视频免费 | 久久爱www久久做| 亚洲国产精品久久久久婷婷884 | 亚洲美女免费视频| 国产校园另类小说区| 4438x亚洲最大成人网| 91麻豆精品秘密| 国产精品自拍av| 激情六月婷婷综合| 日本特黄久久久高潮| 伊人色综合久久天天人手人婷| 国产视频不卡一区| 精品成人免费观看| 欧美一卡二卡三卡四卡| 777亚洲妇女| 欧美日韩精品欧美日韩精品一| 9人人澡人人爽人人精品| 成人综合在线视频| 国产一区二区视频在线播放| 美腿丝袜亚洲三区| 老司机免费视频一区二区| 亚洲一区在线免费观看| 亚洲乱码中文字幕| 亚洲色图在线视频| 成人免费在线观看入口| 国产精品美女久久久久高潮| 久久精品夜夜夜夜久久| wwww国产精品欧美| 久久综合久久鬼色| 久久天天做天天爱综合色| 精品国产乱码久久久久久影片| 欧美日本一道本在线视频| 欧美三级韩国三级日本三斤| 欧美在线一二三四区| 欧美写真视频网站| 欧美日韩国产一区| 日韩一级片网站| 日韩一区二区三区视频| 日韩一区二区影院| 精品免费一区二区三区| 久久精品亚洲乱码伦伦中文| 国产欧美日韩另类一区| 国产精品久久久久永久免费观看| 国产精品成人一区二区艾草| 亚洲色图视频网站| 亚洲国产精品久久久男人的天堂 | 欧美激情一二三区| 亚洲男同1069视频| 精品一区二区三区免费视频| 韩国v欧美v亚洲v日本v| 成人黄页毛片网站| 欧美亚洲国产怡红院影院| 欧美精品vⅰdeose4hd| 日韩欧美国产综合一区| 国产欧美1区2区3区| 亚洲欧洲综合另类| 日本不卡视频在线| 懂色av一区二区三区蜜臀| 日本韩国欧美在线| 欧美一卡二卡三卡| 国产精品久久看| 午夜精品久久久久久久久久| 国产一区不卡视频| 日本精品一级二级| 日韩免费看网站| 亚洲三级在线播放| 捆绑变态av一区二区三区| 成人美女视频在线观看18| 91福利国产精品| 久久综合久久久久88| 亚洲蜜桃精久久久久久久| 美女久久久精品| 91视频免费观看| 精品91自产拍在线观看一区| 亚洲桃色在线一区| 国内精品伊人久久久久av一坑| 色成人在线视频| 国产亚洲1区2区3区| 亚洲国产日韩a在线播放性色| 国产精品资源在线看| 欧美日韩在线不卡| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲成av人片在线| 91蜜桃在线免费视频| 精品国精品国产尤物美女| 亚洲国产色一区| 99久免费精品视频在线观看| 欧美www视频| 日产国产欧美视频一区精品| 91亚洲精品一区二区乱码| 久久免费看少妇高潮| 日韩vs国产vs欧美| 欧美视频一区二区三区| 国产精品国模大尺度视频| 国内精品自线一区二区三区视频| 欧美亚洲禁片免费| 亚洲欧美日韩国产中文在线| 国产夫妻精品视频| 精品久久一区二区| 日本麻豆一区二区三区视频| 欧美午夜精品理论片a级按摩| 国产精品麻豆欧美日韩ww| 国产乱色国产精品免费视频| 91麻豆精品国产91久久久资源速度| 亚洲伦理在线免费看| 91在线国产福利| 亚洲人成网站精品片在线观看| 成人久久久精品乱码一区二区三区| 日韩精品一区二区三区视频| 日韩二区三区在线观看|