亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

通過實例解析JavaScript常用排序算法

瀏覽:108日期:2023-10-16 13:21:28

冒泡排序

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

算法介紹:

比較相鄰的兩個元素,如果前一個比后一個大,則交換位置。第一輪把最大的元素放到了最后面。由于每次排序最后一個都是最大的,所以之后按照步驟1排序最后一個元素不用比較。

通過實例解析JavaScript常用排序算法

冒泡算法改進:

設置一個標志,如果這一趟發生了交換,則為true。否則為false。如果這一趟沒有發生交換,則說明排序已經完成。代碼如下:

通過實例解析JavaScript常用排序算法

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

通過實例解析JavaScript常用排序算法

每一次循環從兩頭出發算出最大和最小值,代碼如下:

通過實例解析JavaScript常用排序算法

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

通過實例解析JavaScript常用排序算法

冒泡排序動圖演示:

通過實例解析JavaScript常用排序算法

快速排序

算法介紹:

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

通過實例解析JavaScript常用排序算法

快速排序動圖演示:

通過實例解析JavaScript常用排序算法

選擇排序

算法介紹:

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

通過實例解析JavaScript常用排序算法

選擇排序動圖演示:

通過實例解析JavaScript常用排序算法

插入排序

算法介紹:

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

通過實例解析JavaScript常用排序算法

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

通過實例解析JavaScript常用排序算法

插入排序法動圖演示:

通過實例解析JavaScript常用排序算法

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 99re7在线精品免费视频 | 国产精品爱久久久久久久电影 | 高h喷水荡肉爽文各种场合 高h辣肉各种姿势爽文bl | 一区二区三区国产精品 | 一级黄片一级毛片 | 49pao强力免费打造在线高清 | 国产二区自拍 | 久青草免费视频手机在线观看 | 亚洲香蕉久久综合网 | 成人亚洲国产精品久久 | 自拍 欧美 | 久久精品91 | 俄罗斯美女bbbbxx | 中文字幕精品视频 | 亚洲日本中文字幕一本 | 国产精品观看在线亚洲人成网 | 一区二区免费播放 | 国产乱码在线精品可播放 | 日韩欧美一中文字幕不卡 | 国产一级视频播放 | 国产高清视频在线播放 | 午夜激情婷婷 | 日本护士xxxx黑人巨大 | 久久综合噜噜激激的五月天 | 日韩免费在线视频观看 | 国产亚洲精品第一区在线观看 | 欧美日本一级在线播放 | 91视频高清 | 黄色一级片播放 | 免费黄网址 | 污污的视频在线播放 | 97色婷婷成人综合在线观看 | 日本片网站 | 欧美日本二区 | 黄网站在线免费 | 国产在线a不卡免费视频 | 国产高清在线精品免费 | 免费看欧美一级特黄a大片一 | 成人在色线视频在线观看免费大全 | 十级毛片| 欧美国产成人在线 |