您現在所在的位置:首頁 >學習資源 > Unity游戲/VR/AR入門教材 > VR開發入門教程43:簡單算法之希爾排序

VR開發入門教程43:簡單算法之希爾排序

來源:奇酷教育 發表于:

VR開發 VR視頻 VR培訓

  希爾排序

  希爾排序Shell Sort是基于插入排序的一種改進,同樣分成兩部分,也稱縮小增量排序

  步驟分析:

  1、準備待排數組[6 2 4 1 5 9]

  2、首先需要選取關鍵字,例如關鍵是3和1(第一步分成三組,第二步分成一組),那么待排數組分成了以下三個虛擬組:[6 1]一組、[2 5]二組、[4 9]三組。注意不是臨近的兩個數字分組,而是下標為3(分成了三組)的倍數的數字的分成了一組,就是每隔3個數取一個,每隔三個再取一個,這樣取出來的數字放到一組,

  3、把它們當成一組,但不實際分組,只是當成一組來看,所以上邊的"組"實際上并不存在,只是為了說明分組關系

  4、對以上三組分別進行插入排序變成下邊這樣

  [1 6] [2 5] [4 9]

  具體過程:

  [6 1]6和1交換變成[1 6]

  [2 5]2與5不動還是[2 5]

  [4 9]4與9不動還是[4 9]

  第一趟排序狀態演示:

  待排數組:[6 2 4 1 5 9]

  排后數組:[1 2 4 6 5 9]

  第二趟關鍵字取的是1,即每隔一個取一個組成新數組,實際上就是只有一組啦,隔一取一就全部取出來了

  此時待排數組為:[1 2 4 6 5 9]

  直接對它進行插入排序

  還記得插入排序怎么排不?復習一下

  [1 2 4]都不用動,過程省略,到5的時候,將5取出,在前邊的有序數組里找到適合它的位置插入,就是4后邊,6前邊

  后邊的也不用改,所以排序完畢

  順序輸出結果:[1 2 4 5 6 9]

  如何選取關鍵字

  希爾排序的關鍵是如何取關鍵字,因為其它內容與插入排序一樣

  那么如何選取關鍵字呢?就是分成三組,一組,這個分組的依據是什么呢?為什么不是二組,六組或者其它組?

  好的增量序列的共同特征:

  ① 最后一個增量必須為1

  ② 應該盡量避免序列中的值(尤其是相鄰的值)互為倍數的情況

  就是說,這個關鍵的選擇是沒有規定的,怎么選都可以,僅一條,關鍵字要越來越小,直到1為止

  增量的取值規則:為第一次取總長度的一半,第二次取一半的一半,依次類推直到1為止

  總的說來希爾對插入排序進行了改造

  原理:為了在插入排序前達到整個序列基本有序的狀態 提高插入排序的效率

  static void ShellSort(int[] unsorted, int len)

  {

  int group, i, j, temp;

  for (group = len / 2; group > 0; group /= 2)

  {

  for (i = group; i < len; i++)

  {

  for (j = i - group; j >= 0; j -= group)

  {

  if (unsorted[j] > unsorted[j + group])

  {

  temp = unsorted[j];

  unsorted[j] = unsorted[j + group];

  unsorted[j + group] = temp;

  }

  }

  }

  }

  }

主站蜘蛛池模板: 亚洲欧美国产∧v精品综合网| 插插插色欲综合网| 亚洲精品天天影视综合网| 久久久久高潮综合影院| 亚洲欧美成人综合在线| 国产成人精品综合久久久| 99久久国产综合精品女同图片| 色婷婷综合久久久中文字幕| 亚洲综合另类小说色区色噜噜| 欧美国产日韩另类综合一区| 亚洲第一综合天堂另类专| 亚洲综合久久久| 一本久道久久综合狠狠躁AV| 亚洲国产成人久久综合一区77| 色婷婷综合在线| 国产精品激情综合久久| 国产成人精品久久综合| 伊人色综合九久久天天蜜桃| 六月婷婷国产精品综合| 91精品国产色综合久久| 青青草原综合久久大伊人导航| 欧美αv日韩αv另类综合 | 国产亚洲综合久久系列| 亚洲综合国产一区二区三区| 久久综合久久综合久久| 亚洲另类激情综合偷自拍图| 丁香五月亚洲综合深深爱| 精品无码综合一区| 久久综合久久综合久久| 伊人色综合久久天天| 国产色综合久久无码有码| 亚洲国产aⅴ综合网| 夜鲁鲁鲁夜夜综合视频欧美| 欧美色综合久久久久久| 亚洲综合亚洲综合网成人| 日本丶国产丶欧美色综合| 亚洲国产综合欧美在线不卡| 一本色道久久综合| 欲香欲色天天综合和网| 综合在线免费视频| 欧美日韩国产综合视频在线看|