• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專(zhuān)題視頻專(zhuān)題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專(zhuān)題1關(guān)鍵字專(zhuān)題50關(guān)鍵字專(zhuān)題500關(guān)鍵字專(zhuān)題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專(zhuān)題關(guān)鍵字專(zhuān)題tag2tag3文章專(zhuān)題文章專(zhuān)題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專(zhuān)題3
    問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
    當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

    JavaScript實(shí)現(xiàn)多種排序算法_javascript技巧

    來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 20:51:24
    文檔

    JavaScript實(shí)現(xiàn)多種排序算法_javascript技巧

    JavaScript實(shí)現(xiàn)多種排序算法_javascript技巧:筆試面試經(jīng)常涉及各種算法,本文簡(jiǎn)要介紹常用的一些算法,并用JavaScript實(shí)現(xiàn)。1、插入排序1)算法簡(jiǎn)介插入排序(Insertion-Sort)的算法描述是一種簡(jiǎn)單直觀的排序算法。它的工作原理是通過(guò)構(gòu)建有序序列,對(duì)于未排序數(shù)據(jù),在已排序序列中從后向前掃描,找到相
    推薦度:
    導(dǎo)讀JavaScript實(shí)現(xiàn)多種排序算法_javascript技巧:筆試面試經(jīng)常涉及各種算法,本文簡(jiǎn)要介紹常用的一些算法,并用JavaScript實(shí)現(xiàn)。1、插入排序1)算法簡(jiǎn)介插入排序(Insertion-Sort)的算法描述是一種簡(jiǎn)單直觀的排序算法。它的工作原理是通過(guò)構(gòu)建有序序列,對(duì)于未排序數(shù)據(jù),在已排序序列中從后向前掃描,找到相

    筆試面試經(jīng)常涉及各種算法,本文簡(jiǎn)要介紹常用的一些算法,并用JavaScript實(shí)現(xiàn)。

    1、插入排序

    1)算法簡(jiǎn)介

    插入排序(Insertion-Sort)的算法描述是一種簡(jiǎn)單直觀的排序算法。它的工作原理是通過(guò)構(gòu)建有序序列,對(duì)于未排序數(shù)據(jù),在已排序序列中從后向前掃描,找到相應(yīng)位置并插入。插入排序在實(shí)現(xiàn)上,通常采用in-place排序(即只需用到O(1)的額外空間的排序),因而在從后向前掃描過(guò)程中,需要反復(fù)把已排序元素逐步向后挪位,為最新元素提供插入空間。

    2)算法描述和實(shí)現(xiàn)

    一般來(lái)說(shuō),插入排序都采用in-place在數(shù)組上實(shí)現(xiàn)。具體算法描述如下:

    從第一個(gè)元素開(kāi)始,該元素可以認(rèn)為已經(jīng)被排序;
    取出下一個(gè)元素,在已經(jīng)排序的元素序列中從后向前掃描;
    如果該元素(已排序)大于新元素,將該元素移到下一位置;
    重復(fù)步驟3,直到找到已排序的元素小于或者等于新元素的位置;
    將新元素插入到該位置后;
    重復(fù)步驟2~5。
    JavaScript代碼實(shí)現(xiàn):

    3)算法分析

    最佳情況:輸入數(shù)組按升序排列。T(n) = O(n)
    最壞情況:輸入數(shù)組按降序排列。T(n) = O(n2)
    平均情況:T(n) = O(n2)
    二、二分插入排序

    1)算法簡(jiǎn)介

    二分插入(Binary-insert-sort)排序是一種在直接插入排序算法上進(jìn)行小改動(dòng)的排序算法。其與直接插入排序算法最大的區(qū)別在于查找插入位置時(shí)使用的是二分查找的方式,在速度上有一定提升。

    2)算法描述和實(shí)現(xiàn)

    一般來(lái)說(shuō),插入排序都采用in-place在數(shù)組上實(shí)現(xiàn)。具體算法描述如下:

    從第一個(gè)元素開(kāi)始,該元素可以認(rèn)為已經(jīng)被排序;
    取出下一個(gè)元素,在已經(jīng)排序的元素序列中二分查找到第一個(gè)比它大的數(shù)的位置;
    將新元素插入到該位置后;
    重復(fù)上述兩步。
    JavaScript代碼實(shí)現(xiàn):

    3)算法分析

    最佳情況:T(n) = O(nlogn)
    最差情況:T(n) = O(n2)
    平均情況:T(n) = O(n2)
    三、選擇排序

    1)算法簡(jiǎn)介

    選擇排序(Selection-sort)是一種簡(jiǎn)單直觀的排序算法。它的工作原理:首先在未排序序列中找到最?。ù螅┰?,存放到排序序列的起始位置,然后,再?gòu)氖S辔磁判蛟刂欣^續(xù)尋找最?。ù螅┰兀缓蠓诺揭雅判蛐蛄械哪┪?。以此類(lèi)推,直到所有元素均排序完畢。

    2)算法描述和實(shí)現(xiàn)

    n個(gè)記錄的直接選擇排序可經(jīng)過(guò)n-1趟直接選擇排序得到有序結(jié)果。具體算法描述如下:

    初始狀態(tài):無(wú)序區(qū)為R[1..n],有序區(qū)為空;
    第i趟排序(i=1,2,3…n-1)開(kāi)始時(shí),當(dāng)前有序區(qū)和無(wú)序區(qū)分別為R[1..i-1]和R(i..n)。該趟排序從當(dāng)前無(wú)序區(qū)中選出關(guān)鍵字最小的記錄 R[k],將它與無(wú)序區(qū)的第1個(gè)記錄R交換,使R[1..i]和R[i+1..n)分別變?yōu)橛涗泜€(gè)數(shù)增加1個(gè)的新有序區(qū)和記錄個(gè)數(shù)減少1個(gè)的新無(wú)序區(qū);
    n-1趟結(jié)束,數(shù)組有序化了。
    JavaScript代碼實(shí)現(xiàn):

    3)算法分析

    最佳情況:T(n) = O(n2)
    最差情況:T(n) = O(n2)
    平均情況:T(n) = O(n2)
    四、冒泡排序

    1)算法簡(jiǎn)介

    冒泡排序是一種簡(jiǎn)單的排序算法。它重復(fù)地走訪(fǎng)過(guò)要排序的數(shù)列,一次比較兩個(gè)元素,如果它們的順序錯(cuò)誤就把它們交換過(guò)來(lái)。走訪(fǎng)數(shù)列的工作是重復(fù)地進(jìn)行直到?jīng)]有再需要交換,也就是說(shuō)該數(shù)列已經(jīng)排序完成。這個(gè)算法的名字由來(lái)是因?yàn)樵叫〉脑貢?huì)經(jīng)由交換慢慢“浮”到數(shù)列的頂端。

    2)算法描述和實(shí)現(xiàn)

    具體算法描述如下:

    比較相鄰的元素。如果第一個(gè)比第二個(gè)大,就交換它們兩個(gè);
    對(duì)每一對(duì)相鄰元素作同樣的工作,從開(kāi)始第一對(duì)到結(jié)尾的最后一對(duì),這樣在最后的元素應(yīng)該會(huì)是最大的數(shù);
    針對(duì)所有的元素重復(fù)以上的步驟,除了最后一個(gè);
    重復(fù)步驟1~3,直到排序完成。
    JavaScript代碼實(shí)現(xiàn):

    3)算法分析

    最佳情況:T(n) = O(n)
    最差情況:T(n) = O(n2)
    平均情況:T(n) = O(n2)
    五、快速排序

    1)算法簡(jiǎn)介

    快速排序的基本思想:通過(guò)一趟排序?qū)⒋庞涗浄指舫瑟?dú)立的兩部分,其中一部分記錄的關(guān)鍵字均比另一部分的關(guān)鍵字小,則可分別對(duì)這兩部分記錄繼續(xù)進(jìn)行排序,以達(dá)到整個(gè)序列有序。

    2)算法描述和實(shí)現(xiàn)

    快速排序使用分治法來(lái)把一個(gè)串(list)分為兩個(gè)子串(sub-lists)。具體算法描述如下:

    從數(shù)列中挑出一個(gè)元素,稱(chēng)為 "基準(zhǔn)"(pivot);
    重新排序數(shù)列,所有元素比基準(zhǔn)值小的擺放在基準(zhǔn)前面,所有元素比基準(zhǔn)值大的擺在基準(zhǔn)的后面(相同的數(shù)可以到任一邊)。在這個(gè)分區(qū)退出之后,該基準(zhǔn)就處于數(shù)列的中間位置。這個(gè)稱(chēng)為分區(qū)(partition)操作;
    遞歸地(recursive)把小于基準(zhǔn)值元素的子數(shù)列和大于基準(zhǔn)值元素的子數(shù)列排序。
    JavaScript代碼實(shí)現(xiàn):

    3)算法分析

    最佳情況:T(n) = O(nlogn)
    最差情況:T(n) = O(n2)
    平均情況:T(n) = O(nlogn)
    六、堆排序

    1)算法簡(jiǎn)介

    堆排序(Heapsort)是指利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計(jì)的一種排序算法。堆積是一個(gè)近似完全二叉樹(shù)的結(jié)構(gòu),并同時(shí)滿(mǎn)足堆積的性質(zhì):即子結(jié)點(diǎn)的鍵值或索引總是小于(或者大于)它的父節(jié)點(diǎn)。

    2)算法描述和實(shí)現(xiàn)

    具體算法描述如下:

    將初始待排序關(guān)鍵字序列(R1,R2....Rn)構(gòu)建成大頂堆,此堆為初始的無(wú)序區(qū);
    將堆頂元素R[1]與最后一個(gè)元素R[n]交換,此時(shí)得到新的無(wú)序區(qū)(R1,R2,......Rn-1)和新的有序區(qū)(Rn),且滿(mǎn)足R[1,2...n-1]<=R[n];
    由于交換后新的堆頂R[1]可能違反堆的性質(zhì),因此需要對(duì)當(dāng)前無(wú)序區(qū)(R1,R2,......Rn-1)調(diào)整為新堆,然后再次將R[1]與無(wú)序區(qū)最后一個(gè)元素交換,得到新的無(wú)序區(qū)(R1,R2....Rn-2)和新的有序區(qū)(Rn-1,Rn)。不斷重復(fù)此過(guò)程直到有序區(qū)的元素個(gè)數(shù)為n-1,則整個(gè)排序過(guò)程完成。
    JavaScript代碼實(shí)現(xiàn):

    3)算法分析

    最佳情況:T(n) = O(nlogn)
    最差情況:T(n) = O(nlogn)
    平均情況:T(n) = O(nlogn)
    七、歸并排序

    1)算法簡(jiǎn)介

    歸并排序是建立在歸并操作上的一種有效的排序算法。該算法是采用分治法(Divide and Conquer)的一個(gè)非常典型的應(yīng)用。歸并排序是一種穩(wěn)定的排序方法。將已有序的子序列合并,得到完全有序的序列;即先使每個(gè)子序列有序,再使子序列段間有序。若將兩個(gè)有序表合并成一個(gè)有序表,稱(chēng)為2-路歸并。

    2)算法描述和實(shí)現(xiàn)

    具體算法描述如下:

    把長(zhǎng)度為n的輸入序列分成兩個(gè)長(zhǎng)度為n/2的子序列;
    對(duì)這兩個(gè)子序列分別采用歸并排序;
    將兩個(gè)排序好的子序列合并成一個(gè)最終的排序序列。
    JavaScript代碼實(shí)現(xiàn):

    3)算法分析

    最佳情況:T(n) = O(n)
    最差情況:T(n) = O(nlogn)
    平均情況:T(n) = O(nlogn)
    八、桶排序

    1)算法簡(jiǎn)介

    桶排序 (Bucket sort)的工作的原理:假設(shè)輸入數(shù)據(jù)服從均勻分布,將數(shù)據(jù)分到有限數(shù)量的桶里,每個(gè)桶再分別排序(有可能再使用別的排序算法或是以遞歸方式繼續(xù)使用桶排序進(jìn)行排序)。

    2)算法描述和實(shí)現(xiàn)

    具體算法描述如下:

    設(shè)置一個(gè)定量的數(shù)組當(dāng)作空桶;
    遍歷輸入數(shù)據(jù),并且把數(shù)據(jù)一個(gè)一個(gè)放到對(duì)應(yīng)的桶里去;
    對(duì)每個(gè)不是空的桶進(jìn)行排序;
    從不是空的桶里把排好序的數(shù)據(jù)拼接起來(lái)。
    JavaScript代碼實(shí)現(xiàn):

    3)算法分析

    桶排序最好情況下使用線(xiàn)性時(shí)間O(n),桶排序的時(shí)間復(fù)雜度,取決與對(duì)各個(gè)桶之間數(shù)據(jù)進(jìn)行排序的時(shí)間復(fù)雜度,因?yàn)槠渌糠值臅r(shí)間復(fù)雜度都為O(n)。很顯然,桶劃分的越小,各個(gè)桶之間的數(shù)據(jù)越少,排序所用的時(shí)間也會(huì)越少。但相應(yīng)的空間消耗就會(huì)增大。

    九、計(jì)數(shù)排序

    1)算法簡(jiǎn)介

    計(jì)數(shù)排序(Counting sort)是一種穩(wěn)定的排序算法。計(jì)數(shù)排序使用一個(gè)額外的數(shù)組C,其中第i個(gè)元素是待排序數(shù)組A中值等于i的元素的個(gè)數(shù)。然后根據(jù)數(shù)組C來(lái)將A中的元素排到正確的位置。它只能對(duì)整數(shù)進(jìn)行排序。

    2)算法描述和實(shí)現(xiàn)

    具體算法描述如下:

    找出待排序的數(shù)組中最大和最小的元素;
    統(tǒng)計(jì)數(shù)組中每個(gè)值為i的元素出現(xiàn)的次數(shù),存入數(shù)組C的第i項(xiàng);
    對(duì)所有的計(jì)數(shù)累加(從C中的第一個(gè)元素開(kāi)始,每一項(xiàng)和前一項(xiàng)相加);
    反向填充目標(biāo)數(shù)組:將每個(gè)元素i放在新數(shù)組的第C(i)項(xiàng),每放一個(gè)元素就將C(i)減去1。
    JavaScript代碼實(shí)現(xiàn):

    3)算法分析

    當(dāng)輸入的元素是n 個(gè)0到k之間的整數(shù)時(shí),它的運(yùn)行時(shí)間是 O(n + k)。計(jì)數(shù)排序不是比較排序,排序的速度快于任何比較排序算法。由于用來(lái)計(jì)數(shù)的數(shù)組C的長(zhǎng)度取決于待排序數(shù)組中數(shù)據(jù)的范圍(等于待排序數(shù)組的最大值與最小值的差加上1),這使得計(jì)數(shù)排序?qū)τ跀?shù)據(jù)范圍很大的數(shù)組,需要大量時(shí)間和內(nèi)存。

    聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    JavaScript實(shí)現(xiàn)多種排序算法_javascript技巧

    JavaScript實(shí)現(xiàn)多種排序算法_javascript技巧:筆試面試經(jīng)常涉及各種算法,本文簡(jiǎn)要介紹常用的一些算法,并用JavaScript實(shí)現(xiàn)。1、插入排序1)算法簡(jiǎn)介插入排序(Insertion-Sort)的算法描述是一種簡(jiǎn)單直觀的排序算法。它的工作原理是通過(guò)構(gòu)建有序序列,對(duì)于未排序數(shù)據(jù),在已排序序列中從后向前掃描,找到相
    推薦度:
    • 熱門(mén)焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門(mén)推薦

    專(zhuān)題
    Top
    主站蜘蛛池模板: 国产麻豆精品一区二区三区v视界| 热re99久久精品国99热| 欧美日韩国产成人高清视频,欧美日韩在线精品一 | 久久精品99久久香蕉国产色戒| 国产精品福利电影一区二区三区四区欧美白嫩精品 | 久久久久99精品成人片三人毛片| 久久99精品国产一区二区三区| 无码精品久久久天天影视| 久久久久人妻精品一区三寸蜜桃| 精品在线免费观看| 国产成人精品免费视频网页大全| 久久夜色精品国产网站| 亚洲国产欧美日韩精品一区二区三区| 国产精品一级AV在线播放| 91精品国产自产在线观看| 日本精品久久久久中文字幕8| 2021国产精品成人免费视频| 亚洲av日韩精品久久久久久a| 人妻少妇看A偷人无码精品视频| 国产精品色视频ⅹxxx| 99热成人精品免费久久| 久久亚洲国产欧洲精品一| 91麻豆精品国产自产在线观看一区| 奇米影视7777久久精品| 亚洲高清国产AV拍精品青青草原| 午夜精品久久久久久| 久久青青草原精品国产软件 | 国产精品白丝AV网站| 国产色婷婷五月精品综合在线 | 国产精品素人搭讪在线播放| 国产精品青青在线观看爽香蕉| 久久久精品一区二区三区| 精品国产免费一区二区三区香蕉| 2021精品国产综合久久| 国产日产韩国精品视频| 国产精品免费无遮挡无码永久视频| 国产在线精品一区二区在线观看| 精品人妻中文字幕有码在线| 精品国产AV一区二区三区| 国产精品视频二区不卡| 91麻豆国产福利精品|