Java 十大排序算法之希爾排序刨析
希爾排序是插入排序的一種,又稱"縮小增量排序”,是插入排序算法的一種更高效的改進版本。
希爾排序原理
1.選定一個增長量h,按照增長量h作為數(shù)據(jù)分組的依據(jù),對數(shù)據(jù)進行分組。
2.對分好組的每一組數(shù)據(jù)完成插入排序。
3.減小增長量,最小減為1,重復(fù)第二步操作。
希爾排序的API設(shè)計
| 類名 | Shell |
| 構(gòu)造方法 | Shell():創(chuàng)建Shell對象 |
| 成員方法 |
1.public static void sort(Comparable[] a):對數(shù)組內(nèi)的元素進行排序 2.private static boolean greater(Comparable v,Comparable w):判斷v是否大于w 3.private static void exchange(Comparable[] a,int i,int j):交換a數(shù)組中,索引i和索引j處的值 |
希爾排序的代碼實現(xiàn)
public class Shell {
//對數(shù)組a中的元素進行排序
public static void sort(Comparable[] a){
int N=a.length;
//確定增長量h的最大值
int h=1;
while(h<N/2){
h=2*h+1;
}
//當增長量h小于1,排序結(jié)束
while(h>=1){
//找到待插入的元素
for(int i=h;i<N;i++){
//a[i]就是待插入的元素
//把a[i]插入到a[i-h],a[i-2h],a[i-3h]...序列中
for(int j=i;j>=h;j-=h){
//a[j]就是待插入的元素,依次和a[j-h],a[j-2h],a[j-3h]進行比較,如果a[j]小,
// 那么交換位置,如果不小于,a[j]大,則插入完成
if(greater(a[j-h],a[j])){
exchange(a,j,j-h);
}else{
break;
}
}
}
h/=2;
}
}
//比較v元素是否大于w元素
private static boolean greater(Comparable v,Comparable w){
return v.compareTo(w)>0;
}
//數(shù)組元素i和j交換位置
private static void exchange(Comparable[] a,int i,int j){
Comparable t=a[i];
a[i]=a[j];
a[j]=t;
}
}
class Test{
public static void main(String[] args) {
Integer[] a={9,1,2,5,7,4,8,6,3,5};
Shell.sort(a);
System.out.println(Arrays.toString(a));
}
}
測試結(jié)果:

由于增量h沒有固定的值,希爾排序的時間復(fù)雜度較為復(fù)雜,但在處理大批量數(shù)據(jù)時,希爾排序的性能高于插入排序!
到此這篇關(guān)于Java 十大排序算法之希爾排序刨析的文章就介紹到這了,更多相關(guān)Java 排序算法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Controller 層返回值的公共包裝類的問題
本文給大家介紹Controller 層返回值的公共包裝類-避免每次都包裝一次返回-InitializingBean增強,本文通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧2021-09-09
java 獲取HttpRequest Header的幾種方法(必看篇)
下面小編就為大家?guī)硪黄猨ava 獲取HttpRequest Header的幾種方法(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09
Java基于websocket協(xié)議與netty實時視頻彈幕交互實現(xiàn)
本文主要介紹了Java基于websocket協(xié)議與netty實時視頻彈幕交互實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
Spring中BeanFactory?FactoryBean和ObjectFactory的三種的區(qū)別
關(guān)于FactoryBean?和?BeanFactory的對比文章比較多,但是對ObjectFactory的描述就比較少,今天我們對比下這三種的區(qū)別,感興趣的朋友跟隨小編一起看看吧2023-01-01
Idea跑的項目沒問題將程序install成jar包運行報錯空指針的問題
這篇文章主要介紹了Idea跑的項目沒問題,將程序install成jar包運行報錯空指針的問題,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06

