懶惰了很久,人有點(diǎn)生銹,所以寫個(gè)算法系列讓自己腦筋活躍起來。
(所有范例一律從小到大排序)
冒泡排序
給定數(shù)組:
var list = [ 54, 26, 93, 17, 77, 31, 44, 88, 55, 20 ];
算法描述:
將第一個(gè)元素與第二個(gè)元素對比,此時(shí)第一個(gè)元素比第二個(gè)元素大,交換他們,這樣較大的元素就位于第二個(gè)位置了;
list = [ 26, 54, 93, 17, 77, 31, 44, 88, 55, 20 ];
將第二個(gè)元素與第三個(gè)元素對比,此時(shí)第二個(gè)元素比第三個(gè)元素小,保持原樣不變;
list = [ 26, 54, 93, 17, 77, 31, 44, 88, 55, 20 ];
重復(fù)上面的步驟,直到最后我們用倒數(shù)第二個(gè)元素與倒數(shù)第一個(gè)元素相比之后,經(jīng)過第一輪排序,最大的元素93被移動(dòng)到了數(shù)組最后;
list = [ 26, 54, 17, 77, 31, 44, 88, 55, 20, 93 ];
然后我們重復(fù)1,2,3步驟;經(jīng)過第二輪我們會(huì)找到次大的元素排在倒數(shù)第二位,即88被移動(dòng)到了數(shù)組倒數(shù)第二位;
list = [ 26, 17, 54, 31, 44, 77, 55, 20, 88, 93 ];
再次重復(fù)直到整個(gè)數(shù)組有序;
第1輪: [ 26, 54, 17, 77, 31, 44, 88, 55, 20, 93 ] 第2輪: [ 26, 17, 54, 31, 44, 77, 55, 20, 88, 93 ] 第3輪: [ 17, 26, 31, 44, 54, 55, 20, 77, 88, 93 ] 第4輪: [ 17, 26, 31, 44, 54, 20, 55, 77, 88, 93 ] 第5輪: [ 17, 26, 31, 44, 20, 54, 55, 77, 88, 93 ] 第6輪: [ 17, 26, 31, 20, 44, 54, 55, 77, 88, 93 ] 第7輪: [ 17, 26, 20, 31, 44, 54, 55, 77, 88, 93 ] 第8輪: [ 17, 20, 26, 31, 44, 54, 55, 77, 88, 93 ] 第9輪: [ 17, 20, 26, 31, 44, 54, 55, 77, 88, 93 ]
算法實(shí)現(xiàn):
function bubble(list) { // 開啟length-1輪循環(huán),因?yàn)樽詈笠惠喼皇R粋€(gè)元素,沒必要比較 for (let i = 0; i < list.length - 1; i++) { // 兩兩對比,每次循環(huán)時(shí)j的取值上限需要舍去尾部已經(jīng)有序的數(shù)據(jù),所以length-1-i for (let j = 0; j < list.length - 1 - i; j++) { if (list[j] > list[j + 1]) { // ES6語法 交換元素 [list[j], list[j + 1]] = [list[j + 1], list[j]]; } } } } // 測試 var list = [ 54, 26, 93, 17, 77, 31, 44, 88, 55, 20 ]; bubble(list); console.log(list); // [ 17, 20, 26, 31, 44, 54, 55, 77, 88, 93 ]
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/93220.html
摘要:懶惰了很久,人有點(diǎn)生銹,所以寫個(gè)算法系列讓自己腦筋活躍起來。所有范例一律從小到大排序選擇排序比冒泡的改進(jìn)是,不會(huì)頻繁交換元素,而只是記錄索引,最后再交換。 懶惰了很久,人有點(diǎn)生銹,所以寫個(gè)算法系列讓自己腦筋活躍起來。 (所有范例一律從小到大排序) 選擇排序比冒泡的改進(jìn)是,不會(huì)頻繁交換元素,而只是記錄索引,最后再交換。 選擇排序 給定數(shù)組: var list = [ 54, 26, 93...
摘要:懶惰了很久,人有點(diǎn)生銹,所以寫個(gè)算法系列讓自己腦筋活躍起來。所有范例一律從小到大排序插入排序的思路可以參考抓撲克牌假定我們已有的撲克牌已經(jīng)有序,現(xiàn)在抓了一張新牌,我們需要插入到適當(dāng)?shù)奈恢靡员3株?duì)列依然有序。 懶惰了很久,人有點(diǎn)生銹,所以寫個(gè)算法系列讓自己腦筋活躍起來。 (所有范例一律從小到大排序) 插入排序的思路可以參考抓撲克牌:假定我們已有的撲克牌已經(jīng)有序,現(xiàn)在抓了一張新牌,我們需要...
摘要:二代碼簡單選擇排序一分析循環(huán)次,每一次的當(dāng)前項(xiàng)與其之后的項(xiàng)作比較,找出其中最小的那個(gè),與當(dāng)前項(xiàng)交換。二代碼希爾排序是一種改進(jìn)版的插入排序,縮小增量排序。這樣做的目的是因?yàn)椋苯硬迦肱判蛟谛蛄谢居行驎r(shí)效率最高。 排序算法 平均情況 最好情況 最壞情況 輔助空間 穩(wěn)定性 冒泡排序 O(n^2) O(n) O(n^2) O(1) 穩(wěn)定 簡單選擇排序 O(n^2) O(n^2)...
摘要:之所以把冒泡排序選擇排序插入排序放在一起比較,是因?yàn)樗鼈兊钠骄鶗r(shí)間復(fù)雜度都為。其中,冒泡排序就是原地排序算法。所以冒泡排序是穩(wěn)定的排序算法。選擇排序思路選擇排序算法的實(shí)現(xiàn)思路有點(diǎn)類似插入排序,也分已排序區(qū)間和未排序區(qū)間。 showImg(https://segmentfault.com/img/bVbuvnj?w=900&h=250); 1. 前言 算法為王。 想學(xué)好前端,先練好內(nèi)功,...
摘要:代碼實(shí)現(xiàn)六堆排序算法簡介堆排序是指利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計(jì)的一種排序算法。九計(jì)數(shù)排序算法簡介計(jì)數(shù)排序是一種穩(wěn)定的排序算法。計(jì)數(shù)排序不是比較排序,排序的速度快于任何比較排序算法。 贊助我以寫出更好的文章,give me a cup of coffee? 2017最新最全前端面試題 1、插入排序 1)算法簡介 插入排序(Insertion-Sort)的算法描述是一種簡單直觀的排序算法。它...
閱讀 2176·2023-04-25 15:00
閱讀 2350·2021-11-18 13:14
閱讀 1171·2021-11-15 11:37
閱讀 3092·2021-09-24 13:55
閱讀 1230·2019-08-30 15:52
閱讀 2650·2019-08-29 12:35
閱讀 3365·2019-08-29 11:04
閱讀 1213·2019-08-26 12:13