數據結構之線索二叉樹



  typedef enum PointerTag{Link,Thread};
  typedef struct{
        char ch;
        int num;
  }ElemType;
  typedef struct{
    BiThrNode *lchild,*rchild;
    PointerTag Ltag,Rtag;
    ElemType data;
  }BiThrNode,*BiThree;


       //中序遍歷記錄線索二叉樹
  void InThreading(BiThree &p,BiThree &pre){
           if(p){
                InThreading(p->lchild,pre);
                if(!(p->lchild)){
                      p->lchild=pre;
                      p->Ltag=Thread;
                  }
                if(!(pre->rchild)){
                      pre->Rtag=Thread;
                      pre->rchild=p;    
                 }        
                pre=p;
               InThreading(p->rchild,pre);
            }
      }


      //創建一個完整的線索二叉樹
  int InorderThreading(BiThree &Thr,BiThree &T){
          BiThrNode *p,*pre;
          if(!Thr=(BiThree)malloc(sizeof(BiThrNode))) exit(1);
          Thr->rchild=Thr;
          Thr->Rtag=Thread;
          pre=Thr;
          if(!T){Thr->lchild=Thr;exit(1);}
          Thr->lchild=T;
          p=T;
          InThreading(p,pre);
          pre->rchild=Thr;
          pre->Rtag=Thread;
          Thr->rchild=pre;    
          return 0;
        }






      //非遞歸中序遍歷線索二叉樹。 
  int InOrderTraverse_Thr(BiThree &T){
          if(!T) exit(1);
          BiThrNode *p=T->lchild;  
          while(p!=T){
                 while(p->Ltag==Link)p=p->lchild;
                 if(visit(p)) return 1;
                 while(p->Rtag==Thread&&p->rchild!=T) 
                 {
                   p=p->rchild;
                   visit(p->rchild);
                 }
                 p=p->rchild;
             }
              return 0;
         }
發佈了129 篇原創文章 · 獲贊 58 · 訪問量 14萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章