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));
}
}
測試結(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)于IDEA關(guān)聯(lián)數(shù)據(jù)庫的問題
這篇文章主要介紹了IDEA關(guān)聯(lián)數(shù)據(jù)庫的相關(guān)知識(shí),本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03
Java實(shí)現(xiàn)定時(shí)任務(wù)的方法總結(jié)
這篇文章主要為大家詳細(xì)介紹了Java中實(shí)現(xiàn)定時(shí)任務(wù)的常用7中方法,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的小伙伴可以參考一下2023-06-06
Java構(gòu)造方法實(shí)例詳解(動(dòng)力節(jié)點(diǎn)java學(xué)院整理)
其實(shí)java構(gòu)造方法很簡單,下面通過示例給大家分享java構(gòu)造方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下2017-04-04
SpringBoot項(xiàng)目如何打可執(zhí)行war包
最近小編做了一個(gè)springboot項(xiàng)目,最后需要打成war包在容器中部署,下面小編給大家分享下SpringBoot項(xiàng)目如何打可執(zhí)行war包,感興趣的朋友一起看看吧2020-04-04
java使用三層架構(gòu)實(shí)現(xiàn)電影購票系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了java使用三層架構(gòu)實(shí)現(xiàn)電影購票系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01
ElasticSearch學(xué)習(xí)之文檔API相關(guān)操作
這篇文章主要為大家介紹了ElasticSearch學(xué)習(xí)之文檔API相關(guān)操作,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01

