基于JavaScript實(shí)現(xiàn)的希爾排序算法分析
本文實(shí)例講述了基于JavaScript實(shí)現(xiàn)的希爾排序算法。分享給大家供大家參考,具體如下:
通過對直接插入排序的分析,可知其時間復(fù)雜度為O(n2),但是,如果待排序序列為正序時,其時間復(fù)雜度可提高至O(n)。希爾排序正是對此進(jìn)行改進(jìn)的排序。希爾排序的核心理念與插入排序不同,它會首先比較距離較遠(yuǎn)的元素,而非相鄰元素。通過定義一個間隔序列來表示在排序過程中進(jìn)行比較的元素之間有多遠(yuǎn)的間隔。
下圖演示了希爾排序中間隔序列是如何運(yùn)行的:
下面我們通過js來實(shí)現(xiàn)希爾排序,代碼如下:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>JavaScript希爾排序</title> </head> <body> <script type="text/javascript"> function shellSort(nums){//希爾排序 var gaps=[5,3,1];//定義間隔區(qū)間 for(var g=0;g<gaps.length;g++){//一個一個間隔值開始 for(var i=gaps[g];i<nums.length;i++){//以間隔值遍歷 var temp=nums[i];//選中元素 for(var j=i;j>=gaps[g]&&nums[j-gaps[g]]>temp;j-=gaps[g]){//如果前面一個大于后面一個 nums[j]=nums[j-gaps[g]];//后移 } nums[j]=temp;//填補(bǔ) } } } function show(nums){//顯示數(shù)組 for(var i=0;i<nums.length;i++){ document.write(nums[i]+' '); } document.write('<br>'); } var nums=[6,0,2,9,3,5,8,0,5,4]; show(nums);//6 0 2 9 3 5 8 0 5 4 shellSort(nums);//希爾排序 show(nums);//0 0 2 3 4 5 5 6 8 9 </script> </body> </html>
其排序過程如下:
希爾排序根據(jù)間隔序列的選取不同,時間復(fù)雜度也不同,但是需要注意,應(yīng)該使間隔序列中的值沒有除1以外的公因子,并且最后一個間隔值必須等于1。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯誤與調(diào)試技巧總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
@ResponseBody 和 @RequestBody 注解的區(qū)別
這篇文章主要介紹了@ResponseBody 和 @RequestBody 注解的區(qū)別的相關(guān)資料,需要的朋友可以參考下2017-03-03Bootstrap實(shí)現(xiàn)導(dǎo)航欄的2種方式
這篇文章主要為大家詳細(xì)介紹了Bootstrap實(shí)現(xiàn)導(dǎo)航欄的2種方式,一是利用按鈕組實(shí)現(xiàn)、二是Bootstrap專門做了相應(yīng)的css類,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11詳解微信小程序-掃一掃 wx.scanCode() 掃碼大變身
這篇文章主要介紹了微信小程序-掃一掃wx.scanCode() 掃碼大變身,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04JavaScript實(shí)現(xiàn)圖片合成下載的示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)圖片合成下載的示例,幫助大家更好的理解和學(xué)習(xí)JavaScript,感興趣的朋友可以了解下2020-11-11