import org.junit.Test;
import java.util.Arrays;
/**
* Created by wc on 2018/4/28.
*/
public class 希爾排序 {
@Test
public void test(){
int[] array={1,9,8,4,2,7,6,5};
sort(array,3);
System.out.print(Arrays.toString(array));
}
/**
* 這是插入排序的變種
* @param array
* @param k 每一次的步長
*/
public void sort(int[] array,int k) {
for (int m = 0; m < k; m++) {
for (int i = m+k; i < array.length; i=i+k) {
int j = i;
int target = array[i];
while (j > k-1 && target < array[j - k]) {
array[j] = array[j - k];
j=j-k;
}
array[j] = target;
}
}
}
}
希爾排序
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
相關(guān)閱讀更多精彩內(nèi)容
- 選擇排序 對于任何輸入,時間為O(n*n); 冒泡排序 最優(yōu)(對于升序的數(shù)組,因為加入了一個跳出判斷):O(n),...
- 給定數(shù)組 int[] arr = {3,6,8,4,7,5,9,1,2,0};使用至少三種方法對數(shù)組arr排序(作...
- 概述 希爾(Shell)排序又稱為縮小增量排序,它是一種插入排序。它是直接插入排序算法的一種威力加強版。 代碼實現(xiàn)...
- 實現(xiàn)兩種初級的排序算法: 選擇排序思路 首先,找到數(shù)組中最小的那個元素,其次,將它和數(shù)組的第一個元素交換位置(如果...