日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

Java排序算法(四)希爾排序2

 小樣樣樣樣樣樣 2021-05-13


希爾排序移步法:分組+直接插入排序組合

一、測(cè)試類SortTest

import java.util.Arrays;

public class SortTest {

  private static final int L = 20;
  public static void main(String[] args) {

  int [] arr = new int[6];
  for (int i = 0; i < arr.length; i++) {
  arr[i] = (int)((Math.random()+1)*L);
  }
  System.out.println(Arrays.toString(arr));
  // new Sort().BubbleSort(arr);
  // new Sort().SelectionSort(arr);
  // new Sort().InsertSort(arr);

  // new Sort().ShellSort1(arr);
  new Sort().ShellSort2(arr);

  System.out.println(Arrays.toString(arr));
  }  
}

二、排序類Sort

  /**
  *
  * <h1>希爾排序-移步法</h1>
  * <ul>
  * <li> 希爾排序移步法,先分組,然后進(jìn)行插入排序
  * </ul>
  * @param arr the array
  * @author linzm
  * @since 1.8
  *
  */
public void ShellSort2(int[] arr) {
  int sep = arr.length/2;
  while(sep >= 1) {
  /*
  *假設(shè)length=8,第一次分組8/2 = 4 組
  *第二次分組,4/2 = 2組 假設(shè)第一組為 3 8 0 -1 2
  *第二次分組的第一組{3, 8, 0, -1, 2}下標(biāo)分別為0, 2, 4, 6
  *first:3 8 0 -1 2
  * second:0 3 8 -1 2(直接插入)3 8 8 -1 2
  * 3 3 8 -1 2
  * 0 2 8 -1 2
  *third:-1 0 3 8 2(直接插入)
  * fourth:-1 0 2 3 8
  *
  */
    for (int i = sep; i < arr.length; i++) {
    // 標(biāo)記待插入變量,右邊往左邊插入
    // 移位法
    // 假設(shè)i=2,j=2
      int j = i - sep;// 被插入位置
      int insertVal = arr[i]; // 待插入數(shù)
      if(arr[j] > arr[j+sep]) {
        while(j >= 0 && insertVal < arr[j]) {
          arr[j+sep] = arr[j];
          j -= sep;
          }
      }
    arr[j+sep] = insertVal;
    }
  sep /= 2;
  }
}

僅供參考,有錯(cuò)誤還請(qǐng)指出! 

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約