国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

JavaScript冒泡算法原理與實現方法深入理解

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

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

在面試中經常會遇到面試官問到冒泡算法。今天總結一下。

###概念

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

我們先假設這一組數是有順序的,那么我們找出它的規則。

JavaScript冒泡算法原理與實現方法深入理解

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

第一輪交換結果:CBAD 交換次數:3次第二輪交換結果:BACD 交換次數:3次第三輪交換結果:ABCD 交換次數:3次

結果:

1.比較輪數 n-12.每次比較次數 n-1

###簡單的冒泡算法

<script>var arr = [1,2,3,4];var temp = null;var m = null;var n = null;// 雙重for循環for(var i=0;i<arr.length-1;i++){//指定交換論數和交換次數(內循環控制交換次數) for(var a=0;a<arr.length-1;a++){if(arr[a]<arr[a+1]){//判斷是否符合標準 temp = arr[a+1]; arr[a+1] = arr[a]; arr[a] = temp;}m++; } n++;}console.log(arr);console.log(m);console.log(n);</script>

得到結果

[4,3,2,1] 排序后9 交換次數3 輪數

在上述的例子中,有重復交換的數據,我們再來分析下。

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

總結:

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

所以,對上述代碼優化。

var arr = [1,2,3,4];var temp = null;var m = null;var n = null;// 雙重for循環for(var i=0;i<arr.length-1;i++){ //指定交換論數和交換次數(內循環控制交換次數) for(var a=0;a<arr.length-1-i;a++){if(arr[a]<arr[a+1]){ //判斷是否符合標準 temp = arr[a+1]; arr[a+1] = arr[a]; arr[a] = temp; } m++; } n++;}console.log(arr);console.log(m);console.log(n);

得到結果。

[4,3,2,1] 排序后6 交換次數3 輪數

再來個稍微復雜點的例子。

<script>var arr = [66,22,23,39,77,25,88];var temp = null;var m = null;var n = null;// 雙重for循環for(var i=0;i<arr.length-1;i++){//指定交換論數和交換次數(內循環控制交換次數) for(var a=0;a<arr.length-1;a++){if(arr[a]<arr[a+1]){ //判斷是否符合標準 temp = arr[a+1]; arr[a+1] = arr[a]; arr[a] = temp; } m++; } n++;}console.log(arr);console.log(m);console.log(n);</script>

結果:

[88, 77, 66, 39, 25, 23, 22]21 少交換了15次6

結果其實已經提前完成,有重復交換次數。這次,我們加個判斷,就是比較本次沒有移動任何元素,那么說明已經完成結果。

<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循環for(var i=0;i<arr.length-1;i++){//指定交換論數和交換次數(內循環控制交換次數) flag = true; for(var a=0;a<arr.length-1-i;a++){if(arr[a]<arr[a+1]){ //判斷是否符合標準 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>

結果:

[88, 77, 66, 39, 33, 25, 23, 23, 22, 11]42 少交換了 39次7 少交換了2 輪

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript數學運算用法總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript數組操作技巧總結》、《JavaScript排序算法總結》、《JavaScript遍歷算法與技巧總結》、《JavaScript查找算法技巧總結》及《JavaScript錯誤與調試技巧總結》

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 在线免费成人 | 亚洲欧美中文在线观看4 | 手机看片在线播放 | 亚洲综合国产一区在线 | 亚洲 欧美 精品 | 欧美.亚洲.日本一区二区三区 | 米奇精品一区二区三区 | www.成人在线视频 | 国产精品揄拍一区二区久久 | 91视频国产精品 | 一级片免费的 | 欧美一级别 | 免费欧洲毛片a级视频无风险 | 91日韩精品天海翼在线观看 | 亚洲精品欧洲久久婷婷99 | 美国毛片亚洲社区在线观看 | 台湾三级 | 996re免费热在线视频手机 | 美国一级毛片片aaa 美国一级毛片片aa成人 | 伊人久久免费 | 欧美日韩视频一区二区三区 | 国内精品美女写真视频 | 特级aaaaaaaaa毛片免费视频 | 成人爽a毛片在线视频网站 成人爽爽大片在线观看 | 992人人tv香蕉国产精品 | 一级毛片在线免费看 | 欧美性猛交xxxxx按摩国内 | 免费一级欧美片在线观免看 | 国产色在线播放 | 久久国产精品歌舞团 | 欧美一级永久免费毛片在线 | 亚洲欧美日韩在线播放 | 欧美一级毛片一免费 | 欧美综合自拍亚洲综合百度 | 国产成人在线视频观看 | 免费国产a国产片高清不卡 免费国产不卡午夜福在线 免费国产不卡午夜福在线观看 | 日韩中文字幕在线观看 | 日韩一级生活片 | 一级特黄aa大片欧美网站 | 欧美另类视频videosbest18 | 成人看片黄a在线看 |