如何理解JavaScript中常用的4種排序算法?

冒泡排序

冒泡排序是我們在編程算法中,算是比較常用的排序算法之一,在學(xué)習(xí)階段,也是最需要接觸理解的算法,所以我們放在第一個來學(xué)習(xí)。

算法介紹:

比較相鄰的兩個元素,如果前一個比后一個大,則交換位置。

第一輪把最大的元素放到了最后面。

由于每次排序最后一個都是最大的,所以之后按照步驟1排序最后一個元素不用比較。

冒泡算法改進:

設(shè)置一個標(biāo)志,如果這一趟發(fā)生了交換,則為true。否則為false。如果這一趟沒有發(fā)生交換,則說明排序已經(jīng)完成。代碼如下:

假如數(shù)組長度是20,如果只有前十位是無序排列的,后十位是有序且都大于前十位,所以第一趟遍歷排序的時候發(fā)生交換的位置必定小于10,且該位置之后的必定有序,我們只需要排序好該位置之前的就可以,因此我們要來標(biāo)記這個位置就可以了,即可以記錄每次掃描中最后一次交換的位置,下次掃描的時候只要掃描到上次的最后交換位置就行了,因為后面的都是已經(jīng)排好序的,無需再比較,代碼如下:

每一次循環(huán)從兩頭出發(fā)算出最大和最小值,代碼如下:

在代碼3的基礎(chǔ)上記錄每次掃描最后一次交換的位置,下次掃描的時候只要掃描到上次的最后交換位置就行,同代碼2,代碼如下:

冒泡排序動圖演示:

快速排序

算法介紹:

快速排序是對冒泡排序的一種改進,第一趟排序時將數(shù)據(jù)分成兩部分,一部分比另一部分的所有數(shù)據(jù)都要小。然后遞歸調(diào)用,在兩邊都實行快速排序。

快速排序動圖演示:

選擇排序

算法介紹:

選擇排序就是從一個未知數(shù)據(jù)空間里,選取之最放到一個新的空間

選擇排序動圖演示:

插入排序

算法介紹:

從第一個默認被排好序的元素開始

取出下一個元素,在已經(jīng)排序的元素序列中從后向前掃描

如果已排序的元素大于取出的元素,則將其分別向后移動一位

直到找到已排序的元素中小于或等于取出的元素,將取出的元素放到它的后一位

重復(fù)步驟2

插入排序算法改進-二分法插入排序:

插入排序法動圖演示:

以上就是4中比較基礎(chǔ)的排序方法了,JavaScript的排序算法還有很多,這是我們4種最常見也是最基本的算法,掌握理解好,在面試和開發(fā)中也能從容應(yīng)對了。

如果你也喜歡學(xué)習(xí)JavaScript,喜歡學(xué)習(xí)前端開發(fā),歡迎關(guān)注公眾號【前端研究所】,每天更新更多教程和學(xué)習(xí)方法哦!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 排序(上):為什么插入排序比冒泡排序更受歡迎? 排序?qū)τ谌魏我粋€程序員來說,可能都不會陌生。你學(xué)的第一個算法,可能...
    GhostintheCode閱讀 3,438評論 4 27
  • 排序算法說明 (1)排序的定義:對一序列對象根據(jù)某個關(guān)鍵字進行排序; 輸入:n個數(shù):a1,a2,a3,…,an 輸...
    code武閱讀 747評論 0 0
  • 本文首發(fā)于我的個人博客:尾尾部落 排序算法是最經(jīng)典的算法知識。因為其實現(xiàn)代碼短,應(yīng)該廣,在面試中經(jīng)常會問到排序算法...
    繁著閱讀 4,681評論 3 118
  • 001 在琳瑯滿目的貨架,挑選一瓶適合的醋真難…… 和愛人去逛超市,要買一瓶食用醋。超市的貨架琳瑯滿目,光各種醋就...
    521杰行天下閱讀 547評論 4 2
  • 后來 她丟失了項鏈 佝僂的鳶尾 有水滴過 是透明的藍色臉譜 笑紋里 藏著風(fēng)月聲 鞋底的沙石 磨成褐色珍珠 別說虛榮...
    十三小滿閱讀 122評論 0 3

友情鏈接更多精彩內(nèi)容