JavaScript中的冒泡排序法
利用sort()冒泡排序:
var arr = [5,39,8,1,2,13,55]; arr = arr.sort(function(a,b){return a-b}); console.log(arr);//1,2,5,8,13,39,55
不聲明第三個(gè)變量冒泡排序:
第一層遍歷數(shù)組的個(gè)數(shù)(要遍歷多少次),第二次遍歷(共要循環(huán)幾次)
a = 10; //第一個(gè)元素 b = 5; //下一個(gè)元素 if(a>b){ a = a+b; // a(15) = 10 +5; b = a-b; // b(10) = 15 - 5; a = a-b; // a(5) = 15 - 10; } var arr = [5,39,8,1,2,13,55]; function jssort(ele){ for (var i=0;i<ele.length;i++){ //要循環(huán)多少次 for (var j=0;j<ele.length-i-1;j++){ //要移動(dòng)幾次 if(ele[j]>ele[j+1]){ ele[j]=ele[j]+ele[j+1]; //a = a+b ele[j+1]=ele[j]-ele[j+1];//b = a-b ele[j]=ele[j]-ele[j+1]; //a = a-b } } } return ele; } console.log(jssort(arr));//1,2,5,8,13,39,55
今天在網(wǎng)上看見這樣一個(gè)冒號(hào)排序
一個(gè)數(shù)組包含元素號(hào),“110金剛3號(hào)”,“200金剛1號(hào)”,“50金剛2號(hào)”,“30金剛6號(hào)”,“30金剛5號(hào)”,“30金剛4號(hào)” 如何根據(jù)字符串中后面的多少號(hào)對(duì)數(shù)組進(jìn)行排序。
答案:利用sort()排序,在回調(diào)函數(shù)中使用正則表達(dá)式
arr.sort(function(a,b){return parseInt(a.match(/(\d+)(?=號(hào))/)[1])-parseInt(b.match(/(\d+)(?=號(hào))/)[1])});
match() 方法可在字符串內(nèi)檢索指定的值,或找到一個(gè)或多個(gè)正則表達(dá)式的匹配。
該方法類似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置。
a.match(/(\d+)(?=號(hào))/ //數(shù)字+零次或一次匹配前面的字符或子表達(dá)式。
下面大家看下js冒泡排序?qū)嵗?/strong>
例子,js實(shí)現(xiàn)冒泡排序的例子。
<html> <head> <script type="text/javascript"> function sort (arr) { for (var i = 0;i<arr.length;i++) { for (var j = 0; j < arr.length-i-1; j++) { if (arr[j]<arr[j+1]) { var temp=arr[j]; arr[j]=arr[j+1]; arr[j+1]=temp; } } } return arr; } var arr=[2,5,3,1,7,8,78,89]; sort(arr); </script> </head> <body> </body> </html>
以上所述是小編給大家介紹的JavaScript中的冒泡排序法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
TypeScript 類class與修飾符的詳細(xì)使用教程
通過 class 關(guān)鍵字定義一個(gè)類,然后通過 new 關(guān)鍵字可以方便的生產(chǎn)一個(gè)類的實(shí)例對(duì)象,這個(gè)生產(chǎn)對(duì)象的過程叫 實(shí)例化,類的成員就是類中所有的屬性和方法,這篇文章主要介紹了TypeScript 類class與修飾符的詳細(xì)使用,需要的朋友可以參考下2022-06-06JavaScript 節(jié)點(diǎn)操作 以及DOMDocument屬性和方法
最近發(fā)現(xiàn)DOMDocument對(duì)象很重要,還有XMLHTTP也很重要 注意大小寫一定不能弄錯(cuò).2007-12-12javascript 瀏覽器檢測(cè)代碼精簡(jiǎn)版
javascript檢測(cè)瀏覽器精簡(jiǎn)版,需要的朋友可以參考下。2010-03-03javascript結(jié)合html5 canvas實(shí)現(xiàn)(可調(diào)畫筆顏色/粗細(xì)/橡皮)的涂鴉板
js+html5 canvas實(shí)現(xiàn)的涂鴉畫板特效,可調(diào)畫筆顏色|粗細(xì)|橡皮,可以保存涂鴉效果為圖片編碼,測(cè)試了下還不錯(cuò),感興趣的朋友可以參考下2013-04-04js實(shí)現(xiàn)本地持久化存儲(chǔ)登錄注冊(cè)
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)本地持久化存儲(chǔ)登錄注冊(cè),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08Bootstrap實(shí)現(xiàn)的標(biāo)簽頁內(nèi)容切換顯示效果示例
這篇文章主要介紹了Bootstrap實(shí)現(xiàn)的標(biāo)簽頁內(nèi)容切換顯示效果,結(jié)合完整實(shí)例形式分析了基于Bootstrap實(shí)現(xiàn)的標(biāo)簽頁內(nèi)容切換顯示功能相關(guān)操作技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2017-05-05