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

您的位置:首頁技術(shù)文章
文章詳情頁

JavaScript冒泡算法原理與實(shí)現(xiàn)方法深入理解

瀏覽:36日期:2023-10-24 08:21:20

本文實(shí)例講述了JavaScript冒泡算法。分享給大家供大家參考,具體如下:

在面試中經(jīng)常會(huì)遇到面試官問到冒泡算法。今天總結(jié)一下。

###概念

有一組數(shù),依次比較兩個(gè)相鄰的數(shù),如果他們的順序(如從大到小或從小到大等)錯(cuò)誤就把他們交換過來。

我們先假設(shè)這一組數(shù)是有順序的,那么我們找出它的規(guī)則。

JavaScript冒泡算法原理與實(shí)現(xiàn)方法深入理解

我們按照從小到大的順序依次交換長方形,得到以下的結(jié)果。

第一輪交換結(jié)果:CBAD 交換次數(shù):3次第二輪交換結(jié)果:BACD 交換次數(shù):3次第三輪交換結(jié)果:ABCD 交換次數(shù):3次

結(jié)果:

1.比較輪數(shù) n-12.每次比較次數(shù) n-1

###簡單的冒泡算法

<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è)賮矸治鱿隆?/p>

第一輪交換:第一次: 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è)最大值或最小值,然后后一輪沒有必要再比較了所以每比較一輪,就少比較一次。在第二輪的時(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ù)

再來個(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è)判斷,就是比較本次沒有移動(dòng)任何元素,那么說明已經(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測試上述代碼運(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ì)有所幫助。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 美女免费观看一区二区三区 | 亚洲xx网| 成人免费国产gav视频在线 | 久久国产经典 | 成人国产亚洲欧美成人综合网 | 久热久色| 国产成人a毛片 | 成 人色 网 站www | 最新三级网站 | 国产日韩视频一区 | 日韩 欧美 国产 亚洲 中文 | 超级极品白嫩美女在线 | 国产综合成人久久大片91 | 一级毛片网| 国产91免费视频 | 亚洲美女操 | 成人免费视频网站 | 农村黄a三级三级三级 | 免费的a级毛片 | 欧美高清色视频在线播放 | 免费黄色网址在线播放 | 免费毛片a | 国产挤奶水在线视频播放 | 国产色综合天天综合网 | 中国一级毛片在线观看 | 国产在线拍偷自揄观看视频网站 | 国产无限制自拍 | 一级做a爱 一区 | 亚洲国产精品日韩高清秒播 | 亚洲毛片大全 | 欧美国产亚洲精品高清不卡 | www.色涩涩.com | 狠狠色噜噜综合社区 | 国产农村妇女一级毛片视频片 | 日韩一区二区免费视频 | 最刺激黄a大片免费观看下截 | 亚洲精品一区二区三区国产 | 黄色片aaa| 亚洲地址一地址二地址三 | 不卡精品国产_亚洲人成在线 | 亚洲欧美一区二区三区久久 |