好程式設計師Java學習路線帶你5分鐘瞭解希爾排序
好程式設計師Java學習路線帶你5分鐘瞭解希爾排序,前言:希爾排序(shell sort)是插入排序的一種,它是簡單插入排序經過改進之後的一個更高效的演算法,這個排序方法又稱為縮小增量排序。
希爾排序思想介紹
簡單來說,希爾排序是將較大的資料集合邏輯上分割成若干個小的集合,然後對每個分組分別進行插入排序。
例如,假設待排序元素序列有n個元素,首先取一個整數increment(小於n)作為間隔將全部元素分為increment個子序列,在每一個子序列中分別實行直接插入排序。然後縮小間隔increment,重複上述子序列劃分和排序工作。直到最後取increment=1,將所有元素放在同一個子序列中排序為止。
演算法說明:
待排序資料:12,1,6,7,4,10,5,9
第一次的增量為陣列元素的長度/2,即increment=4,得到四個分組:
分組一:12, 4
分組二: 1, 10
分組三: 6, 5
分組四: 7, 9
對這四個分組分別進行插入排序,最終得到:
4,1,5,7,12,10,6,9
第二次比較,increment取上次值的一半,即increment=2,得到兩個分組:
分組一:4, 5, 12, 6
分組二: 1, 7, 10, 9
對這兩個分組分別進行插入排序,最終得到:
4, 1, 5,7, 6,9,12,10
第三次比較,increment=1,即只有一個分組:
分組一:4,1,5,7,6,9,12,10
對其進行插入排序,最終得到:
1,4,5,6,7,9,10,12
希爾排序的程式碼實現
1. public static void shellSort( int [] arr){
2. int temp = 0;
3. int j = 0;
4. //增量初始值是長度的一半,增量每次變為原來的一半
5. for ( int inc = arr.length/2 ; inc >= 1 ; inc /= 2){
6. for ( int i = inc ; i < arr.length; i++){
7. temp = arr ;
8. //將當前數與減去增量之後位置的數進行比較,如果大於,則後移
9. for (j = i - inc; j >=0; j -= inc){
10. if (arr[j] > temp){
11. arr[j + inc] = arr[j];
12. } else {
13. break ;
14. }
15. }
16. arr[j + inc]=temp;
17. }
18. }
19. }
總結
希爾排序是插入排序的改進,但是希爾排序中使用到了多次插入排序,在不同的插入排序過程中,相同的元素在各自的插入排序中可能會移動,造成排序的穩定性被打亂,所以希爾排序是不穩定的。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69913892/viewspace-2651044/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 好程式設計師Java學習路線分享5分鐘瞭解計數排序程式設計師Java排序
- 好程式設計師Java學習路線分享5分鐘瞭解基數排序程式設計師Java排序
- 好程式設計師Java教程教你5分鐘瞭解快速排序程式設計師Java排序
- 好程式設計師告訴你Java架構師學習路線程式設計師Java架構
- 好程式設計師Java學習路線之集程式設計師Java
- 好程式設計師Java乾貨分享5分鐘瞭解折半插入排序程式設計師Java排序
- 好程式設計師Java學習路線分享氣泡排序及最佳化程式設計師Java排序
- 好程式設計師Java學習路線JSP物件程式設計師JavaJS物件
- 好程式設計師Java學習路線分享SpringCloud程式設計師JavaSpringGCCloud
- 好程式設計師Java學習路線分享finalize()方法詳解程式設計師Java
- 好程式設計師web前端學習路線分享瞭解AJAX是什麼程式設計師Web前端
- 好程式設計師Java學習路線分享mybatis對映程式設計師JavaMyBatis
- 帶你真正瞭解Java,Java程式設計師必學知識點整理Java程式設計師
- 好程式設計師Java學習路線分享Java框架怎麼搭建程式設計師Java框架
- 好程式設計師Java學習路線分享Redis快速入門程式設計師JavaRedis
- 好程式設計師Java學習路線分享JVM相關概念程式設計師JavaJVM
- 好程式設計師Java學習路線分享MyBatis之基本使用程式設計師JavaMyBatis
- 好程式設計師Java學習路線分享maven是什麼程式設計師JavaMaven
- 好程式設計師Java學習路線分享原生Ajax的使用程式設計師Java
- 好程式設計師Java學習路線分享Java-String常用方法程式設計師Java
- 好程式設計師Java學習路線分享Java中的位移運算程式設計師Java
- 好程式設計師Java學習路線Java bean是個什麼概念程式設計師JavaBean
- 好程式設計師Java學習路線之MySQL的執行計劃程式設計師JavaMySql
- 好程式設計師Java學習路線分享MyBatis之Spring整合程式設計師JavaMyBatisSpring
- 好程式設計師Java學習路線分享Dubbo架構介紹程式設計師Java架構
- 好程式設計師Java學習路線分享多執行緒概念程式設計師Java執行緒
- 好程式設計師Java學習路線分享MySQL目錄結構程式設計師JavaMySql
- 好程式設計師Java學習路線分享SpringMVC之MVC概述程式設計師JavaSpringMVC
- 好程式設計師Java學習路線分享三大特性之多型程式設計師Java多型
- 好程式設計師Java學習路線之SpringMVC之基本配置程式設計師JavaSpringMVC
- 好程式設計師web前端帶你瞭解JS的作用域鏈程式設計師Web前端JS
- 好程式設計師Java學習路線分享Java弱引用的理解與使用程式設計師Java
- 好程式設計師Java學習路線分享Java案例-封裝JDBC工具類程式設計師Java封裝JDBC
- 好程式設計師Java學習路線介紹Java到底是什麼?程式設計師Java
- 好程式設計師Java學習路線分享怎麼理解Java物件導向程式設計師Java物件
- 好程式設計師web前端學習路線分享Jsonp詳解程式設計師Web前端JSON
- 好程式設計師大資料學習路線分享AWK詳解程式設計師大資料
- 好程式設計師Python學習路線分享實現快速排序演算法程式設計師Python排序演算法