演算法單鏈錶快速排序演算法實現

dongyu2013發表於2014-04-15
  1. typedef int ElemType;  
  2. typedef struct ListNode* List;  
  3.   
  4. struct ListNode  
  5. {  
  6.     ElemType key  
  7.     List     next;  
  8. };  

實現程式碼如下:



  1. void QuickSort( List head, List tail )  
  2. {  
  3.     if ( head->next == tail || head->next->next == tail )  
  4.         return;  
  5.   
  6.     List mid = head->next;  
  7.     List p = head;  
  8.     List q = mid;  
  9.     ElemType pivot = mid->key;  
  10.     List t = mid->next;  
  11.       
  12.     while ( t != tail )  
  13.     {  
  14.         if ( t->key 
  15.             p = p->next = t;  
  16.         else  
  17.             q = q->next = t;  
  18.         t = t->next;  
  19.     }  
  20.     p->next = mid;  
  21.     q->next = tail;  
  22.   
  23.     QuickSort( head, mid );  
  24.     QuickSort( mid, tail );  
  25. }  


呼叫時引數head為(帶頭節點的)單連結串列頭節點指標,tail為單連結串列尾節點的next指標指向的類容。通常情況下tail的內容為NULL,因此,呼叫時為QuickSort(head, NULL)。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29012686/viewspace-1142673/,如需轉載,請註明出處,否則將追究法律責任。

相關文章