舉例說(shuō)明javascript冒泡排序
一、什么是冒泡排序
冒泡排序,Bubble Sort,通過(guò)依次來(lái)比較相鄰兩個(gè)元素的大小,在每一次的比較的過(guò)程中,兩個(gè)元素,通過(guò)交換來(lái)達(dá)到有序的目的。
如果一組無(wú)序的數(shù)列想要從小到大排序,那么兩個(gè)元素比較,通過(guò)交換來(lái)實(shí)現(xiàn),左邊的元素要比右邊的元素要小。
如果一組無(wú)序的數(shù)列想要從大到小排序,那么兩個(gè)元素比較,通過(guò)交換來(lái)實(shí)現(xiàn),左邊的元素要比右邊的元素要大。
就像碳酸飲料中的氣泡一樣,從底部一直冒泡到頂部。
二、舉個(gè)例子
假如有 2,4,7,5,3,6,1 這組數(shù)
第一輪:
i=0;
j(內(nèi)層循環(huán))循環(huán) 6次,內(nèi)層循環(huán)做的工作:相鄰兩個(gè)數(shù)比較,大的最終會(huì)放在后面,小的在前,一次循環(huán)外層循環(huán)控制次數(shù),內(nèi)層循環(huán)做判斷
j=0 1 2 3 4 5
2 2 2 2 2 2 2
4 4 4 4 4 4 4
7 7 7 5 5 5 5
5 5 5 7 3 3 3
3 3 3 3 7 6 6
6 6 6 6 6 7 1
1 1 1 1 1 1 7
arr[0] arr[1] arr[2]
arr[1] arr[2] arr[3]
第二輪:
i=1;
j(內(nèi)層循環(huán))循環(huán) 5次
j=0 1 2 3 4 5
2 2 2 2 2 2
4 4 4 4 4 4
5 5 5 3 3 3
3 3 3 5 5 5
6 6 6 6 6 1
1 1 1 1 1 6
7 7 7 7 7 7
arr[0] arr[1] arr[2]
arr[1] arr[2] arr[3]
第三輪:
i=2;
j(內(nèi)層循環(huán))循環(huán) 4次
2 2 2 2 2
4 4 3 3 3
3 3 4 4 4
5 5 5 5 1
1 1 1 1 5
6 6 6 6 6
7 7 7 7 7
第四輪:
i=3;
j(內(nèi)層循環(huán))循環(huán) 3次
2 2 2 2
3 3 3 3
4 4 4 1
1 1 1 4
5 5 5 5
6 6 6 6
7 7 7 7
第五輪:
i=4;
2 2 2
3 3 1
1 1 3
4 4 4
5 5 5
6 6 6
7 7 7
第六輪:
i=5;
2 1
1 2
3 3
4 4
5 5
6 6
7 7
*/
<script type="text/javascript" >
// 示例1:
function show(){
var arr=[2,4,7,5,3,6,1];
for(var i=0;i<arr.length-1;i++){
for(var j=0;j<arr.length-1-i;j++){
//1、比較相鄰的兩個(gè)數(shù);大的在后,小的在前
if(arr[j] > arr[j+1] ){
var temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
console.log(arr);
}
// 示例2:
<body>
<input type="text" id="test">
<button type="button" onclick="show()">按我</button>
<input type="text" id="sc">
</body>
function show() {
let oT=document.getElementById("test").value;
let sc=document.getElementById("sc");
// console.log(sc);
// console.log(oT);
let arr=oT.split("");
console.log(arr.length);
for (var i = 0; i < arr.length - 1; i++) {
for (var j = 0; j < arr.length - 1 - i; j++) {
//1、比較相鄰的兩個(gè)數(shù);大的在后,小的在前
if (arr[j] > arr[j + 1]) {
var temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
// console.log(arr);
sc.value=arr;
}
</script>
總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
JavaScript通過(guò)元素索引號(hào)刪除數(shù)組中對(duì)應(yīng)元素的方法
這篇文章主要介紹了JavaScript通過(guò)元素索引號(hào)刪除數(shù)組中對(duì)應(yīng)元素的方法,涉及javascript操作數(shù)組的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-03-03
JS實(shí)現(xiàn)網(wǎng)絡(luò)請(qǐng)求的三種方式梳理
本文主要為大家介紹了基于 XMLHttpRequest、Promise、async/await 等三種異步網(wǎng)絡(luò)請(qǐng)求的寫法,文中的示例代碼講解詳細(xì),感興趣的可以學(xué)習(xí)一下2022-03-03
微信小程序movable-view的可移動(dòng)范圍示例詳解
這篇文章主要介紹了微信小程序movable-view的可移動(dòng)范圍?,movable-view不管怎么移動(dòng)都要完全包含住movable-area,也就是說(shuō)movable-area不能超出movable-view的區(qū)域范圍,反之亦然,本文通過(guò)示例介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
JavaScript實(shí)現(xiàn)繪制兩個(gè)坐標(biāo)之間的連線
本文主要介紹了JavaScript實(shí)現(xiàn)繪制兩個(gè)坐標(biāo)之間的連線功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-11-11
其實(shí)你可以少寫點(diǎn)if else與switch(推薦)
switch case與if else的區(qū)別:switch case會(huì)生成一個(gè)跳轉(zhuǎn)表來(lái)指示實(shí)際的case分支的地址,而if...else卻需要遍歷條件分支直到命中條件,下面這篇文章主要給大家介紹了關(guān)于if else與switch在使用中的一些技巧,需要的朋友可以參考下2019-01-01
原生JavaScript中直接觸發(fā)事件的方式小結(jié)
JavaScript提供了多種方式來(lái)直接觸發(fā)事件,無(wú)論是在用戶交互、程序邏輯處理或是數(shù)據(jù)更新時(shí),本文將全面探討原生JavaScript中各種事件觸發(fā)方式,并通過(guò)深入的技術(shù)案例分析,需要的朋友可以參考下2025-01-01
javascript 廣告后加載,加載完頁(yè)面再加載廣告
網(wǎng)頁(yè)打開的順序都是按頁(yè)面從上到下的順序加載完成的,所以要想使廣告不影響頁(yè)面打開速度,就要等頁(yè)面全部打開完成后,再加載JS代碼。2010-11-11

