Java 十大排序算法之希爾排序刨析
希爾排序是插入排序的一種,又稱"縮小增量排序”,是插入排序算法的一種更高效的改進(jìn)版本。
希爾排序原理
1.選定一個增長量h,按照增長量h作為數(shù)據(jù)分組的依據(jù),對數(shù)據(jù)進(jìn)行分組。
2.對分好組的每一組數(shù)據(jù)完成插入排序。
3.減小增長量,最小減為1,重復(fù)第二步操作。
希爾排序的API設(shè)計(jì)
類名 | Shell |
構(gòu)造方法 | Shell():創(chuàng)建Shell對象 |
成員方法 |
1.public static void sort(Comparable[] a):對數(shù)組內(nèi)的元素進(jìn)行排序 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處的值 |
希爾排序的代碼實(shí)現(xiàn)
public class Shell { //對數(shù)組a中的元素進(jìn)行排序 public static void sort(Comparable[] a){ int N=a.length; //確定增長量h的最大值 int h=1; while(h<N/2){ h=2*h+1; } //當(dāng)增長量h小于1,排序結(jié)束 while(h>=1){ //找到待插入的元素 for(int i=h;i<N;i++){ //a[i]就是待插入的元素 //把a(bǔ)[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]進(jìn)行比較,如果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增強(qiáng),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-09-09java 獲取HttpRequest Header的幾種方法(必看篇)
下面小編就為大家?guī)硪黄猨ava 獲取HttpRequest Header的幾種方法(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09Java高級之虛擬機(jī)加載機(jī)制的實(shí)例講解
下面小編就為大家分享一篇Java高級之虛擬機(jī)加載機(jī)制的實(shí)例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12Java基于websocket協(xié)議與netty實(shí)時視頻彈幕交互實(shí)現(xiàn)
本文主要介紹了Java基于websocket協(xié)議與netty實(shí)時視頻彈幕交互實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09基于JavaMail實(shí)現(xiàn)郵件發(fā)送
這篇文章主要為大家詳細(xì)介紹了基于JavaMail實(shí)現(xiàn)郵件發(fā)送功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-03-03Spring中BeanFactory?FactoryBean和ObjectFactory的三種的區(qū)別
關(guān)于FactoryBean?和?BeanFactory的對比文章比較多,但是對ObjectFactory的描述就比較少,今天我們對比下這三種的區(qū)別,感興趣的朋友跟隨小編一起看看吧2023-01-01Idea跑的項(xiàng)目沒問題將程序install成jar包運(yùn)行報錯空指針的問題
這篇文章主要介紹了Idea跑的項(xiàng)目沒問題,將程序install成jar包運(yùn)行報錯空指針的問題,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06