Java 十大排序算法之希爾排序刨析
希爾排序是插入排序的一種,又稱"縮小增量排序”,是插入排序算法的一種更高效的改進(jìn)版本。
希爾排序原理
1.選定一個(gè)增長量h,按照增長量h作為數(shù)據(jù)分組的依據(jù),對(duì)數(shù)據(jù)進(jìn)行分組。
2.對(duì)分好組的每一組數(shù)據(jù)完成插入排序。
3.減小增長量,最小減為1,重復(fù)第二步操作。
希爾排序的API設(shè)計(jì)
| 類名 | Shell |
| 構(gòu)造方法 | Shell():創(chuàng)建Shell對(duì)象 |
| 成員方法 |
1.public static void sort(Comparable[] a):對(duì)數(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 {
//對(duì)數(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));
}
}
測(cè)試結(jié)果:

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

