通過實例解析JavaScript常用排序算法
冒泡排序
冒泡排序是我們在編程算法中,算是比較常用的排序算法之一,在學習階段,也是最需要接觸理解的算法,所以我們放在第一個來學習。
算法介紹:
比較相鄰的兩個元素,如果前一個比后一個大,則交換位置。第一輪把最大的元素放到了最后面。由于每次排序最后一個都是最大的,所以之后按照步驟1排序最后一個元素不用比較。

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

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

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

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

冒泡排序動圖演示:

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

快速排序動圖演示:

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

選擇排序動圖演示:

插入排序
算法介紹:
從第一個默認被排好序的元素開始取出下一個元素,在已經(jīng)排序的元素序列中從后向前掃描如果已排序的元素大于取出的元素,則將其分別向后移動一位直到找到已排序的元素中小于或等于取出的元素,將取出的元素放到它的后一位重復步驟2

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

插入排序法動圖演示:

以上就是4中比較基礎(chǔ)的排序方法了,JavaScript的排序算法還有很多,這是我們4種最常見也是最基本的算法,掌握理解好,在面試和開發(fā)中也能從容應(yīng)對了。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript事件函數(shù)中獲得事件源的兩種不錯方法
許多情況我們需要獲得事件源對象來對其屬性進行更改,在事件響應(yīng)函數(shù)中獲得事件源的方法有如下兩種2014-03-03
js用Date對象的setDate()函數(shù)對日期進行加減操作
在某個日期上加減天數(shù)來說,其實只要調(diào)用Date對象的setDate()函數(shù)就可以了,具體方法如下2014-09-09
Javascript設(shè)計模式理論與編程實戰(zhàn)之簡單工廠模式
簡單工廠模式是由一個方法來決定到底要創(chuàng)建哪個類的實例, 而這些實例經(jīng)常都擁有相同的接口. 這種模式主要用在所實例化的類型在編譯期并不能確定, 而是在執(zhí)行期決定的情況。 說的通俗點,就像公司茶水間的飲料機,要咖啡還是牛奶取決于你按哪個按鈕2015-11-11
JavaScript實現(xiàn)的石頭剪刀布游戲源碼分享
這篇文章主要介紹了JavaScript實現(xiàn)的石頭剪刀布游戲源碼分享,挺好玩的小游戲,關(guān)鍵在一些算法上,需要的朋友可以參考下2014-08-08
從數(shù)組中隨機取x條不重復數(shù)據(jù)的JS代碼
這篇文章主要介紹了從數(shù)組中隨機取x條不重復數(shù)據(jù)的JS代碼,有需要的朋友可以參考一下2013-12-12

