Java集合(14)--雙樞軸快速排序(DualPivotQuicksort)

來源:互聯網
上載者:User

標籤:

 

JDK1.7  java.uti.Arrays開始使用DualPivotQuicksort作為預設排序方法

詳細講解連結:http://www.tuicool.com/articles/BfY7Nz

演算法思想:

選出兩個樞軸P1和P2,需要3個指標L,K,G。

3個指標的作用如:

 

演算法為以下的步驟:(數組大小小於286時,使用DualPivotQuicksort)

1、 小於47的數組,使用插入排序。

2、選擇樞軸P1和P2。(假設使用數組頭和尾)。

3、P1需要小於P2,否者交換。

現在數組被分成4份,left到L的小於P1的數,L到K的大於P1小於P2的數,G到rigth的大於P2的數,待處理的K到G的中間的數(逐步被處理到前3個地區中)。

//關鍵演算法部分

4、L從開始初始化直至不小於P1,K初始化為L-1,G從結尾初始化直至不大於P2。K是主移動的指標,來一步一步吞噬中間地區。

****當大於P1小於P2,K++。

****當小於P1,交換L和K的數,L++,K++。

****當大於P2,如果G的數小於P1,把L上的數放在K上,把G的數放在L上,L++,再把K以前的數放在G上,G--,K++,完成一次L,K,G的互相交換。否則交換K和G,並G--,K++。

5、遞迴4。

6、交換P1到L-1上。交換P2到G+1上。

7、遞迴之。

 

流程圖:

 

 

Java集合(14)--雙樞軸快速排序(DualPivotQuicksort)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.