日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

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

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

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

###概念

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

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

JavaScript冒泡算法原理與實現(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ù),我們再來分析下。

第一輪交換:第一次: 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é):

每一輪都會比較出一個最大值或最小值,然后后一輪沒有必要再比較了所以每比較一輪,就少比較一次。在第二輪的時候,有一個數(shù)不參與交換。在第三輪的時候,有兩個數(shù)不參與交換。依次類推。

所以,對上述代碼優(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ù)

再來個稍微復(fù)雜點的例子。

<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é)果其實已經(jīng)提前完成,有重復(fù)交換次數(shù)。這次,我們加個判斷,就是比較本次沒有移動任何元素,那么說明已經(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代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)學(xué)運算用法總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯誤與調(diào)試技巧總結(jié)》

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
老色鬼精品视频在线观看播放| 亚洲欧洲日韩| 国产精品夜夜夜| 日韩综合小视频| 日韩和欧美一区二区| 日本精品在线播放| 国产亚洲精品精品国产亚洲综合| 69堂免费精品视频在线播放| 91精品日本| 国产精品18| 成人国产精品久久| 免费日韩成人| 精品久久国产一区| 国产成人精品免费视| 久久青青视频| 999国产精品视频| 在线视频精品| 日韩一区精品| 久久精品国产亚洲一区二区三区| 高清日韩欧美| 国精品一区二区| 日韩精品一二三| 日韩精品三级| 久久亚洲精品中文字幕| 日韩在线中文| 99视频一区| 亚洲ww精品| 麻豆视频观看网址久久| 人人草在线视频| 夜夜嗨av一区二区三区网站四季av| 日韩在线黄色| 精品欠久久久中文字幕加勒比| 国产在视频一区二区三区吞精| 日韩精品看片| 亚洲图片久久| 久久99久久久精品欧美| 日韩大片在线播放| 亚洲综合丁香| 国产精品久久久久久久久久久久久久久 | 好看不卡的中文字幕| 鲁大师成人一区二区三区 | 亚洲一区二区三区四区电影| 国产探花在线精品一区二区| 午夜久久中文| 亚洲欧美网站在线观看| 黄色网一区二区| 久久国产精品亚洲77777| 国产精品午夜av| 在线视频观看日韩| 日本精品久久| 久久精品人人| 尤物精品在线| 国产精品久久久久久妇女| 色婷婷狠狠五月综合天色拍| 亚洲久草在线| 中文在线а√在线8| 美女精品在线| 精品免费视频| 蜜桃av一区二区在线观看| 精品午夜av| 午夜在线视频观看日韩17c| 久久超级碰碰| 亚洲欧美日韩视频二区| 精品五月天堂| 亚洲日本久久| 日韩深夜视频| 欧美亚洲三区| 99国产精品久久久久久久成人热| 精品美女在线视频| 亚洲精品无播放器在线播放| 色爱av综合网| 国产精品多人| 自拍自偷一区二区三区| 久久久久99| 美女在线视频一区| 亚洲综合图色| 99pao成人国产永久免费视频| 国产成人免费精品| 日韩欧美中文字幕在线视频| 欧洲毛片在线视频免费观看| 欧美激情精品| 亚洲精品福利| 午夜一区在线| 欧美色图一区| 成人国产综合| 国产精品麻豆成人av电影艾秋| 免费在线观看精品| av亚洲在线观看| 日韩精品午夜| 日韩影院二区| 中国字幕a在线看韩国电影| 欧美激情一区| 国产欧美日韩免费观看| 亚洲毛片视频| 免费人成黄页网站在线一区二区| 五月激情久久| 国语对白精品一区二区| 欧美精品中文| 少妇高潮一区二区三区99| 日韩一级精品| 五月综合激情| 亚洲特级毛片| 99久久夜色精品国产亚洲狼| av资源中文在线| 精品欧美日韩精品| 卡一卡二国产精品| 久久99精品久久久野外观看| 日本天堂一区| 日韩不卡一区二区| 亚洲精品乱码日韩| 99在线|亚洲一区二区| 国内精品福利| 久久精品99久久无色码中文字幕| 日韩电影免费网址| 日韩在线中文| 99国产精品免费视频观看| 日韩一区二区在线免费| 成人午夜精品| 亚洲二区在线| 91久久视频| 香蕉久久夜色精品国产| 免费不卡中文字幕在线| 激情六月综合| 狠狠干成人综合网| 日韩视频久久| 中国女人久久久| 伊人久久大香线蕉av超碰演员| 黄色成人在线网址| 老色鬼久久亚洲一区二区| 性欧美长视频| 亚洲精品美女91| 青草国产精品| 欧美激情视频一区二区三区免费 | 国产欧美一区二区三区米奇| 国产麻豆一区| 精品一区二区三区四区五区| 国产在线观看91一区二区三区| 中文字幕在线视频久| 少妇久久久久| 欧美女激情福利| 免费在线观看日韩欧美| 青草国产精品| 国产成人精品福利| 亚洲国内欧美| 伊人精品久久| 日韩精彩视频在线观看| 国产精品片aa在线观看| 国产成人免费精品| 欧美/亚洲一区| 男女激情视频一区| 国产私拍福利精品视频二区| 久久精品理论片| 亚洲韩日在线| 日本亚洲三级在线| 久久99久久人婷婷精品综合| 最新中文字幕在线播放| 午夜日本精品| 日韩高清不卡在线| 久久精品人人| 亚洲国产不卡| 日韩不卡免费视频| 国内在线观看一区二区三区| 久久香蕉国产| 亚洲精品乱码| 国产999精品在线观看| 国产高清一区| 91欧美极品| 精品免费av在线| 亚洲日本在线观看视频| 久久久久伊人| 不卡视频在线| 国产欧美一区二区三区国产幕精品| a天堂资源在线| 日韩精品一区第一页| 久久男人av| 黄色成人精品网站| 欧美精品1区| 亚洲一区二区三区免费在线观看| 91大神在线观看线路一区| 美女av在线免费看| 亚洲精品日本| 日韩一区三区| 日韩精品免费一区二区夜夜嗨| 国产成人免费| 老司机精品久久| 国产成人免费| 亚洲精品三级| 激情综合在线| 奇米亚洲欧美| 91久久中文| а√天堂8资源中文在线| 亚洲精品第一| 欧美 日韩 国产一区二区在线视频| 久久国际精品| 日韩视频免费| 亚洲综合电影| 国产日韩亚洲欧美精品| 欧美日韩免费观看一区=区三区| 国产精品成人自拍| 亚洲欧美日韩一区在线观看|