JavaScript冒泡算法原理與實(shí)現(xiàn)方法深入理解
本文實(shí)例講述了JavaScript冒泡算法。分享給大家供大家參考,具體如下:
在面試中經(jīng)常會(huì)遇到面試官問(wèn)到冒泡算法。今天總結(jié)一下。
###概念
有一組數(shù),依次比較兩個(gè)相鄰的數(shù),如果他們的順序(如從大到小或從小到大等)錯(cuò)誤就把他們交換過(guò)來(lái)。
我們先假設(shè)這一組數(shù)是有順序的,那么我們找出它的規(guī)則。

我們按照從小到大的順序依次交換長(zhǎng)方形,得到以下的結(jié)果。
第一輪交換結(jié)果:CBAD 交換次數(shù):3次
第二輪交換結(jié)果:BACD 交換次數(shù):3次
第三輪交換結(jié)果:ABCD 交換次數(shù):3次
結(jié)果:
1.比較輪數(shù) n-1
2.每次比較次數(shù) n-1
###簡(jiǎn)單的冒泡算法
<script>
var arr = [1,2,3,4];
var temp = null;
var m = null;
var n = null;
// 雙重for循環(huán)
for(var i=0;i<arr.length-1;i++){
//指定交換論數(shù)和交換次數(shù)(內(nèi)循環(huán)控制交換次數(shù))
for(var a=0;a<arr.length-1;a++){
if(arr[a]<arr[a+1]){
//判斷是否符合標(biāo)準(zhǔn)
temp = arr[a+1];
arr[a+1] = arr[a];
arr[a] = temp;
}
m++;
}
n++;
}
console.log(arr);
console.log(m);
console.log(n);
</script>
得到結(jié)果
[4,3,2,1] 排序后
9 交換次數(shù)
3 輪數(shù)
在上述的例子中,有重復(fù)交換的數(shù)據(jù),我們?cè)賮?lái)分析下。
第一輪交換:
第一次: 2 1 3 4
第二次: 2 3 1 4
第三次: 2 3 4 1
第二輪交換:
第一次: 3 2 4 1
第二次: 3 4 2 1
第三次: 3 4 2 1
第三輪交換:
第一次: 4 3 2 1
第二次: 4 3 2 1
第三次: 4 3 2 1
總結(jié):
每一輪都會(huì)比較出一個(gè)最大值或最小值,然后后一輪沒(méi)有必要再比較了
所以每比較一輪,就少比較一次。在第二輪的時(shí)候,有一個(gè)數(shù)不參與交換。
在第三輪的時(shí)候,有兩個(gè)數(shù)不參與交換。依次類推。
所以,對(duì)上述代碼優(yōu)化。
var arr = [1,2,3,4];
var temp = null;
var m = null;
var n = null;
// 雙重for循環(huán)
for(var i=0;i<arr.length-1;i++){
//指定交換論數(shù)和交換次數(shù)(內(nèi)循環(huán)控制交換次數(shù))
for(var a=0;a<arr.length-1-i;a++){
if(arr[a]<arr[a+1]){
//判斷是否符合標(biāo)準(zhǔn)
temp = arr[a+1];
arr[a+1] = arr[a];
arr[a] = temp;
}
m++;
}
n++;
}
console.log(arr);
console.log(m);
console.log(n);
得到結(jié)果。
[4,3,2,1] 排序后
6 交換次數(shù)
3 輪數(shù)
再來(lái)個(gè)稍微復(fù)雜點(diǎn)的例子。
<script>
var arr = [66,22,23,39,77,25,88];
var temp = null;
var m = null;
var n = null;
// 雙重for循環(huán)
for(var i=0;i<arr.length-1;i++){
//指定交換論數(shù)和交換次數(shù)(內(nèi)循環(huán)控制交換次數(shù))
for(var a=0;a<arr.length-1;a++){
if(arr[a]<arr[a+1]){
//判斷是否符合標(biāo)準(zhǔn)
temp = arr[a+1];
arr[a+1] = arr[a];
arr[a] = temp;
}
m++;
}
n++;
}
console.log(arr);
console.log(m);
console.log(n);
</script>
結(jié)果:
[88, 77, 66, 39, 25, 23, 22]
21 少交換了15次
6
結(jié)果其實(shí)已經(jīng)提前完成,有重復(fù)交換次數(shù)。這次,我們加個(gè)判斷,就是比較本次沒(méi)有移動(dòng)任何元素,那么說(shuō)明已經(jīng)完成結(jié)果。
<script>
var arr = [66,22,23,39,77,25,88,11,33,23];
var temp = null;
var m = null;
var n = null;
var flag = true;
// 雙重for循環(huán)
for(var i=0;i<arr.length-1;i++){
//指定交換論數(shù)和交換次數(shù)(內(nèi)循環(huán)控制交換次數(shù))
flag = true;
for(var a=0;a<arr.length-1-i;a++){
if(arr[a]<arr[a+1]){
//判斷是否符合標(biāo)準(zhǔn)
temp = arr[a+1];
arr[a+1] = arr[a];
arr[a] = temp;
flag = false;
}
m++;
}
n++;
if(flag){
break;
}
}
console.log(arr);
console.log(m);
console.log(n);
</script>
結(jié)果:
[88, 77, 66, 39, 33, 25, 23, 23, 22, 11]
42 少交換了 39次
7 少交換了2 輪
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- 通過(guò)js示例講解時(shí)間復(fù)雜度與空間復(fù)雜度
- Javascript校驗(yàn)密碼復(fù)雜度的正則表達(dá)式
- JS算法教程之字符串去重與字符串反轉(zhuǎn)
- 如何通過(guò)JS實(shí)現(xiàn)日歷簡(jiǎn)單算法
- 基于JS實(shí)現(xiàn)計(jì)算24點(diǎn)算法代碼實(shí)例解析
- 基于原生js實(shí)現(xiàn)九宮格算法代碼實(shí)例
- JS求解兩數(shù)之和算法詳解
- js實(shí)現(xiàn)無(wú)限層級(jí)樹形數(shù)據(jù)結(jié)構(gòu)(創(chuàng)新算法)
- 如何用JavaScript學(xué)習(xí)算法復(fù)雜度
相關(guān)文章
BootStrap 智能表單實(shí)戰(zhàn)系列(二)BootStrap支持的類型簡(jiǎn)介
這篇文章主要介紹了BootStrap 智能表單實(shí)戰(zhàn)系列(二)BootStrap支持的類型簡(jiǎn)介 的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧2016-06-06
bootstrap——bootstrapTable實(shí)現(xiàn)隱藏列的示例
本篇文章主要介紹了bootstrapTable實(shí)現(xiàn)隱藏列的示例,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01
js從數(shù)組中刪除指定值(不是指定位置)的元素實(shí)現(xiàn)代碼
下面小編就為大家?guī)?lái)一篇js從數(shù)組中刪除指定值(不是指定位置)的元素實(shí)現(xiàn)代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09
JavaScript實(shí)現(xiàn)移動(dòng)端拖動(dòng)元素
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)移動(dòng)端拖動(dòng)元素,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11
javascript算法學(xué)習(xí)(直接插入排序)
假設(shè)待排序的記錄存放在數(shù)組R[1..n]中。初始時(shí),R[1]自成1個(gè)有序區(qū),無(wú)序區(qū)為R[2..n]。從i=2起直至i=n為止,依次將R[i]插入當(dāng)前的有序區(qū)R[1..i-1]中,生成含n個(gè)記錄的有序區(qū)。2011-04-04
JS中art-template模板使用過(guò)濾器問(wèn)題
這篇文章主要介紹了JS中art-template模板使用過(guò)濾器問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09

