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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? treeiter.h

?? 數據結構學過的各種算法及其ppt演示
?? 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;
  }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
捆绑调教一区二区三区| 国产原创一区二区| 欧美一级久久久久久久大片| 99精品久久只有精品| 性做久久久久久免费观看欧美| 久久久久久久久久看片| 欧美欧美午夜aⅴ在线观看| 成年人国产精品| 91在线porny国产在线看| 成人av网站在线观看免费| 国产一区二区三区香蕉| 韩国v欧美v亚洲v日本v| 国产一区二区在线视频| 国产成人精品在线看| 国产福利一区二区三区视频在线| 国产一区二区91| 成人黄色av电影| 色域天天综合网| 欧美日韩免费一区二区三区视频| 欧美日韩一级大片网址| 日韩一区二区在线看| 久久久久久久av麻豆果冻| 国产精品全国免费观看高清 | 7777精品久久久大香线蕉 | 一区二区三区蜜桃| 亚洲国产精品视频| 青青草伊人久久| 国产精品一线二线三线| 成人免费高清视频在线观看| 在线亚洲一区二区| 欧美一区在线视频| 久久九九全国免费| 亚洲欧洲av另类| 亚洲va韩国va欧美va| 奇米精品一区二区三区四区| 国产精品69毛片高清亚洲| 91视频www| 日韩一区二区三区电影| 欧美激情一区二区| 亚洲成人激情社区| 成人永久免费视频| 欧美日韩一二三区| 日本一区二区电影| 视频一区视频二区中文字幕| 国产福利一区二区三区| 欧美日韩一区三区| 国产精品美女视频| 日本不卡中文字幕| 91在线国内视频| 欧美不卡一区二区三区四区| 一区二区三区四区在线免费观看| 成人欧美一区二区三区白人| 另类小说综合欧美亚洲| 欧美高清你懂得| 久久毛片高清国产| 亚洲成人第一页| 国产精品白丝jk白祙喷水网站| 日韩欧美电影一二三| 久久免费的精品国产v∧| 亚洲欧美乱综合| 精品一区二区免费看| 欧美日韩免费高清一区色橹橹| 成人高清视频在线观看| 欧美肥妇free| **网站欧美大片在线观看| 久久av中文字幕片| 精品婷婷伊人一区三区三| 国产视频一区在线播放| 美脚の诱脚舐め脚责91| 欧美色中文字幕| 国产精品久久久久久久久久久免费看| 免费久久99精品国产| 91黄色免费版| 国产精品久久久久久户外露出| 经典三级在线一区| 欧美精品粉嫩高潮一区二区| 亚洲啪啪综合av一区二区三区| 国产福利91精品一区二区三区| 欧美精品高清视频| 亚洲444eee在线观看| 99久久精品情趣| 中文一区一区三区高中清不卡| 美腿丝袜在线亚洲一区| 欧美一区二视频| 亚洲成人自拍一区| 欧美三级欧美一级| 亚洲精品乱码久久久久久| av中文一区二区三区| 亚洲国产精品ⅴa在线观看| 久久超碰97人人做人人爱| 日韩三级伦理片妻子的秘密按摩| 香蕉久久夜色精品国产使用方法| 91丨九色丨蝌蚪富婆spa| 中文字幕在线不卡| 成人sese在线| 国产精品国产三级国产专播品爱网| 国产高清在线观看免费不卡| 久久日韩精品一区二区五区| 精品亚洲国内自在自线福利| 日韩一区二区在线播放| 蜜桃视频免费观看一区| 欧美不卡视频一区| 激情综合一区二区三区| 久久女同精品一区二区| 国产乱人伦精品一区二区在线观看| 亚洲精品一区二区在线观看| 精品无人区卡一卡二卡三乱码免费卡| 精品国产免费一区二区三区香蕉 | 大陆成人av片| 亚洲男人的天堂网| 欧美日韩另类国产亚洲欧美一级| 在线国产电影不卡| 高清久久久久久| 亚洲国产精品影院| 国产香蕉久久精品综合网| 色婷婷国产精品久久包臀| 久久99精品国产麻豆婷婷洗澡| 日韩电影在线免费| 久久久久久久综合狠狠综合| 色菇凉天天综合网| caoporn国产一区二区| 欧美亚洲动漫制服丝袜| 久久久久久久国产精品影院| 成人免费毛片aaaaa**| 亚洲视频免费在线| 欧美视频在线播放| 日本网站在线观看一区二区三区| 精品sm在线观看| 成人av高清在线| 一区二区三区高清| 日韩午夜激情电影| 成人高清视频在线观看| 亚洲国产精品久久一线不卡| 欧美一区二区黄色| 国产盗摄视频一区二区三区| 亚洲男人天堂av网| 91精品国产91热久久久做人人| 国产一区二区三区四区在线观看| 中文字幕一区二区三区四区不卡| 欧美系列日韩一区| 国产一区视频网站| 亚洲宅男天堂在线观看无病毒| 日韩亚洲欧美在线观看| 成人晚上爱看视频| 婷婷激情综合网| 欧美高清在线精品一区| 欧美日韩和欧美的一区二区| 国产酒店精品激情| 亚洲成av人片在www色猫咪| 久久久久亚洲综合| 欧美日韩电影一区| 成人av电影在线播放| 日韩av二区在线播放| 中文字幕日韩av资源站| 91精品国产免费| 91色.com| 国产露脸91国语对白| 午夜欧美视频在线观看| 中文文精品字幕一区二区| 欧美精品日日鲁夜夜添| gogo大胆日本视频一区| 精品一区二区三区在线观看国产| 亚洲视频一区二区在线观看| 欧美电影免费观看高清完整版在| 色婷婷综合久色| 国产美女视频91| 日韩中文字幕一区二区三区| ...中文天堂在线一区| 久久久综合视频| 91精品国产综合久久久久久久 | 久久人人97超碰com| 舔着乳尖日韩一区| 色8久久精品久久久久久蜜| 青椒成人免费视频| 欧美午夜精品理论片a级按摩| 日韩视频免费直播| 国产精品99久久久久久久女警| 国产成人免费视频精品含羞草妖精| 99精品视频中文字幕| 日韩免费高清电影| 一区二区三区中文字幕精品精品| 黄色小说综合网站| 一区二区三区不卡视频| 国产精品每日更新| 91啦中文在线观看| 亚洲国产一区二区视频| 国产亚洲精品资源在线26u| 久久这里只有精品6| 成人黄色大片在线观看| 另类中文字幕网| 天天爽夜夜爽夜夜爽精品视频| 欧美v国产在线一区二区三区| 国产激情一区二区三区四区 | 国产日产欧美一区| 911精品产国品一二三产区| 在线观看不卡视频| 色94色欧美sute亚洲线路一ni| 成人国产精品免费观看| 粉嫩蜜臀av国产精品网站| 韩国精品免费视频|