日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > java >内容正文

java

插入排序---希尔插入排序算法(Javascript版)

發(fā)布時間:2023/12/19 java 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 插入排序---希尔插入排序算法(Javascript版) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

取一個小于n的整數(shù)作為第一個增量,把序列分組。所有距離為增量的倍數(shù)的元素放在同一個組中。先在各組內(nèi)進(jìn)行直接插入排序;然后,取第二個增量(第二個<第一個)重復(fù)上述的分組和排序,直至所取的增量=1,即所有元素放在同一組中進(jìn)行直接插入排序?yàn)橹埂?/p>

?

一般的初次取序列的一半為增量,以后每次減半,直到增量為1。

?

以下代碼在nodejs中執(zhí)行通過。

function shellInsertSort(elements, di){//從增量的所在位置開始for(var i = di; i < elements.length; i++){//升序if(elements[i] < elements[i-di]){//取出增量位置的元素作為被插入元素(哨兵)var guard = elements[i];var j = i - di;elements[i] = elements[j];//向前,將增量的倍數(shù)的位置作為同一組比較及進(jìn)行直接插入法while(j >= 0 && guard < elements[j]){elements[j+di] = elements[j];j -= di;}//插入elements[j + di] = guard;}} }function shellSort(elements){//增量為序列的一半var di = parseInt(elements.length / 2);while(di >= 1){shellInsertSort(elements, di);//每次減半,最后增量必須為1di = parseInt(di / 2);} }var elements = [10, 9, 8, 7, 6, 5]; console.log('before: ' + elements); shellSort(elements); console.log(' after: ' + elements);

?

效率:比直接插入法快。但不是一種穩(wěn)定的排序算法,關(guān)鍵取決于增量的選擇,初次通常選取序列長度的一半。

(轉(zhuǎn)帖):希爾排序時間復(fù)雜度的下界是n*log2n。希爾排序沒有快速排序算法快 O(n(logn)),因此中等大小規(guī)模表現(xiàn)良好,對規(guī)模非常大的數(shù)據(jù)排序不是最優(yōu)選擇。但是比O(n^2)復(fù)雜度的算法快得多。并且希爾排序非常容易實(shí)現(xiàn),算法代碼短而簡單。 此外,希爾算法在最壞的情況下和平均情況下執(zhí)行效率相差不是很多,與此同時快速排序在最壞的情況下執(zhí)行的效率會非常差。專家們提倡,幾乎任何排序工作在開始時都可以用希爾排序,若在實(shí)際使用中證明它不夠快,再改成快速排序這樣更高級的排序算法. 本質(zhì)上講,希爾排序算法是直接插入排序算法的一種改進(jìn),減少了其復(fù)制的次數(shù),速度要快很多。 原因是,當(dāng)n值很大時數(shù)據(jù)項(xiàng)每一趟排序需要的個數(shù)很少,但數(shù)據(jù)項(xiàng)的距離很長。當(dāng)n值減小時每一趟需要和動的數(shù)據(jù)增多,此時已經(jīng)接近于它們排序后的最終位置。 正是這兩種情況的結(jié)合才使希爾排序效率比插入排序高很多。
在希爾排序開始時增量較大,分組較多,每組的記錄數(shù)目少,故各組內(nèi)直接插入較快,后來增量di逐漸縮小,分組數(shù)逐漸減少,而各組的記錄數(shù)目逐漸增多,但由于已經(jīng)按di-1作為距離排過序,使文件較接近于有序狀態(tài),所以新的一趟排序過程也較快。

?

總結(jié)

以上是生活随笔為你收集整理的插入排序---希尔插入排序算法(Javascript版)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。