亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

淺談javascript 歸并方法

 更新時間:2015年01月21日 10:32:22   投稿:hebedich  
這篇文章主要介紹了淺談javascript 歸并方法的相關(guān)資料,需要的朋友可以參考下

ECMAScript5為數(shù)組定義了2個歸并方法:reduce()和reduceRight()。這兩個方法都會迭代數(shù)組的隨意項,然后構(gòu)建一個最終返回的值。reduce()方法從數(shù)組的第一項開始,逐個遍歷到數(shù)組的最后。reduceRight()方法則剛好相反,它從數(shù)組的最后一項開始,向前遍歷到第一項。

這兩個方法都接收兩個參數(shù):一個在每一項上調(diào)用的函數(shù)和作為歸并基礎(chǔ)的初始值。傳給reduce()和reduceRight()的函數(shù)接收4個參數(shù):前一個值,當(dāng)前值,項的索引和數(shù)組對象。這個函數(shù)返回的任何值都會作為第一個參數(shù)自動傳給下一項。第一次迭代發(fā)生在數(shù)組的第二項上,因此第一個參數(shù)是數(shù)組的第一項,第二個參數(shù)就是數(shù)組的第二項。

例如,我們可以使用reduce()方法來求數(shù)組中所有值的總和。

var nums = [1,2,3,4,5];
var sum = nums.reduce(function(prev,cur,index,array){
 retrun pre + cur;
});

上面的代碼中,第一次執(zhí)行回調(diào)函數(shù),prev是1,cur是2。第二次prev是3,cur是3。reduce()方法會重復(fù)這個過程,直到把數(shù)組中的每一項都訪問一次,最后將返回的結(jié)果賦值給sum。

reduceRight()方法的左右類似,只不過是反向執(zhí)行。例如:

var nums = [1,2,3,4,5];
var sum = nums.reduceRight(function(prev,cur,index,array){
 retrun pre + cur;
});

這個例子中,第一次執(zhí)行回調(diào)函數(shù),prev是5,cur是4。最后求和的結(jié)果和reduce()方法相同,都是15。

支持reduce()和reduceRight()的瀏覽器有:IE9+,F(xiàn)irefox3+,Safari4+,Opeera10.5+和Chrome。

補充

ECMAScript5 還新增了2個歸并數(shù)組的方法:reduce()和reduceRight()。

 這兩個都會迭代數(shù)組的所有項
        reduce():從第一項開始逐個遍歷到最后。
        reduceRight():從數(shù)組的最后一項開始,遍歷到數(shù)組的第一項。

這兩個方法都接受兩個參數(shù):在每一項上調(diào)用的函數(shù)(參數(shù)為:前一個值,當(dāng)前值,項的索引,數(shù)組對象)

 這個函數(shù)返回的任何值斗毆會作為第一個參數(shù)自動傳給下一項。第一次迭代發(fā)生在數(shù)組的第二項上,
         因此第一個參數(shù)是數(shù)組的第一項,第二個參數(shù)是數(shù)組的第二項
         和 作為歸并基礎(chǔ)的初始值。
        使用reduce()方法可以執(zhí)行數(shù)組中所有值之和的操作,比如:

    var values = [1, 2, 3, 4, 5];
    var sum = values.reduce(function (prev, cur, index, array) {
      return prev + cur;
    });
    alert(sum);
    //結(jié)果一樣,只是方向相反而已
    var sum2=values.reduceRight(function (prev,cur,index,array) {
      return prev+cur;
    });
    alert(sum2);

歸并排序(Merge sort)是建立在歸并操作上的一種有效的排序算法。該算法是采用分治法(Divide and Conquer)的一個非常典型的應(yīng)用。

歸并(Merge)排序法是將兩個(或兩個以上)有序表合并成一個新的有序表,即把待排序序列分為若干個子序列,每個子序列是有序的。然后再把有序子序列合并為整體有序序列。

歸并排序是建立在歸并操作上的一種有效的排序算法。該算法是采用分治法(Divide and Conquer)的一個非常典型的應(yīng)用。將已有序的子序列合并,得到完全有序的序列;即先使每個子序列有序,再使子序列段間有序。若將兩個有序表合并成一個有序表,稱為2-路歸并。

相關(guān)文章

最新評論