欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js 3種歸并操作的實例代碼

 更新時間:2013年10月30日 16:05:47   作者:  
這篇文章介紹了js 3種歸并操作的實例代碼,有需要的朋友可以參考一下

第一種:

復(fù)制代碼 代碼如下:

/**良哥的*/
function merge(a, b) {
    var aLen = a.length,
        bLen = b.length,
        maxLen = Math.max(aLen, bLen),
        sumLen = aLen + bLen,
        result = [],
        ap = 0,
        bp = 0;

     while (result.length < sumLen) {
        if (ap < aLen && bp < bLen) {
            if(a[ap] > b[bp]){
                result.push(b[bp++]);
            } else {
                result.push(a[ap++]);
            }
        } else if (!(ap < aLen)){
            while(bp < bLen){
                result.push(b[bp++]);
            }
        } else if (!(bp < bLen)){
            while(ap < aLen){
                result.push(a[ap++]);
            }
        }
    }
    return result;
}

第二種:

復(fù)制代碼 代碼如下:

/**魯軍*/
function merge(arr1, arr2){

    var i = 0;
    var j = 0;
    var c = 0;
    var k;
    var len1 = arr1.length;
    var len2 = arr2.length;
    var arr = [];
    for(;i<len1 && j<len2;){
        if( arr1[i] > arr2[j]  ){
            arr.push( arr2[j] );
            j++;
        }else{
            arr.push( arr1[i] );
            i++;
        }
        //if(i==len1 || j==len2){
        //    break;
        //}
    }

    if(i==len1){
        //arr = arr.concat(arr2.slice(j));

        for(k=j; k<len2; k++){
            arr.push( arr2[k] );
        }
    }

    if(j==len2){
        //arr = arr.concat(arr1.slice(i))
        for(k=i; k<len1; k++){
            arr.push( arr1[k] );
        }

    }

    return arr;
}

第三種:

復(fù)制代碼 代碼如下:

/*金銳的*/
function merge(a,b){
    var x = 0;
    var l = 0;
    var list = [];
    var aLen = a.length;
    var bLen = b.length;

    for(var i = 0; i < bLen; i++){
        for(var j = x; j < aLen; j++){
            if(b[i] < a[j]){
                list.push(b[i]);
                l = i;
                break;
            }else{               
                list.push(a[j]);
                x++;
            }
        }    
    }           

    if(x == a.length){
        for(var y = l; y < bLen; y++){
            list.push(b[y]);
        }
    }else{
        for(var z = x; z < aLen; z++){
            list.push(a[z]);
        }
    }

    return list;
}

經(jīng)過測試2個有序20W長度的數(shù)組歸并耗時都在15毫秒以下。

以下有幾條經(jīng)驗(在大量操作的時候才能體現(xiàn),平時不需要做這樣的優(yōu)化。代碼可讀性還是第一原則)

1:數(shù)組的concat方法比直接for循環(huán)push要慢。

2:for循環(huán)比while循環(huán)快。

3:var a = b || 3; //這種操作很消耗時間

4: break,continue 在已確定不需要再循環(huán)時很耗時。

相關(guān)文章

  • js模擬實現(xiàn)煙花特效

    js模擬實現(xiàn)煙花特效

    這篇文章主要為大家詳細介紹了js模擬實現(xiàn)煙花特效,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 原生JS:Date對象全面解析

    原生JS:Date對象全面解析

    下面小編就為大家?guī)硪黄鶭S:Date對象全面解析。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • 在webstorm中配置less的方法詳解

    在webstorm中配置less的方法詳解

    這篇文章主要介紹了在webstorm中配置less的方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2020-09-09
  • 讓多個輸入框中的內(nèi)容同時變化的js代碼

    讓多個輸入框中的內(nèi)容同時變化的js代碼

    怎么樣讓多個輸入框中的內(nèi)容同時變化?一般又要兼容IE與firefox
    2010-01-01
  • JavaScript類的繼承操作實例總結(jié)

    JavaScript類的繼承操作實例總結(jié)

    這篇文章主要介紹了JavaScript類的繼承操作,結(jié)合實例形式總結(jié)分析了JavaScript面向?qū)ο蟪绦蛟O(shè)計中類的繼承常見實現(xiàn)方式與操作技巧,需要的朋友可以參考下
    2018-12-12
  • 顯示/隱藏側(cè)邊欄

    顯示/隱藏側(cè)邊欄

    顯示/隱藏側(cè)邊欄...
    2006-10-10
  • 深入理解js函數(shù)的作用域與this指向

    深入理解js函數(shù)的作用域與this指向

    下面小編就為大家?guī)硪黄钊肜斫鈐s函數(shù)的作用域與this指向。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • 原生JS實現(xiàn)酷炫分頁效果

    原生JS實現(xiàn)酷炫分頁效果

    這篇文章主要為大家詳細介紹了原生JS實現(xiàn)酷炫分頁效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • JS獲取iframe中marginHeight和marginWidth屬性的方法

    JS獲取iframe中marginHeight和marginWidth屬性的方法

    這篇文章主要介紹了JS獲取iframe中marginHeight和marginWidth屬性的方法,涉及javascript操作iframe屬性的技巧,并分析了marginHeight和marginWidth屬性的功能,非常具有實用價值,需要的朋友可以參考下
    2015-04-04
  • JS提示:Uncaught SyntaxError: Unexpected token ILLEGAL錯誤的解決方法

    JS提示:Uncaught SyntaxError: Unexpected token ILLEGAL錯誤的解決方法

    這篇文章主要介紹了JS提示:Uncaught SyntaxError: Unexpected token ILLEGAL錯誤的解決方法,涉及針對字符串參數(shù)的處理方法,需要的朋友可以參考下
    2016-08-08

最新評論