成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

關(guān)于Array.reduce的理解與拓展

keithxiaoy / 1725人閱讀

摘要:而則從數(shù)組的最后一項開始,向前遍歷到第一項。傳給和的函數(shù)接收個參數(shù)前一個值當前值項的索引和數(shù)組對象。這個函數(shù)返回的任何值都會作為第一個參數(shù)自動傳給下一項。第二次,是加的結(jié)果,是數(shù)組的第三項。

2018年1月6日
首先我要感謝我的同事徒步上山看日出在我第一份實習的時候?qū)ξ业闹笇?現(xiàn)在我也開始跟他一樣開始養(yǎng)成寫博客的習慣
現(xiàn)在開始討論我遇到的第一個問題,這是我在看javascript高級程序設(shè)計看的一個令像我這樣的新手值得思考的問題
文章思路

什么是array的reduce,用法?

什么是迭代==>(在學校學的被狗吃了系列~)


關(guān)于Array.ruduce( )
書中是這么寫的

ECMAScript 5 還新增了兩個歸并數(shù)組的方法: reduce()和 reduceRight()。這兩個方法都會迭代數(shù)組的所有項,然后構(gòu)建一個最終返回的值。其中, reduce()方法從數(shù)組的第一項開始,逐個遍歷到最后。而 reduceRight()則從數(shù)組的最后一項開始,向前遍歷到第一項。

這兩個方法都接收兩個參數(shù):一個在每一項上調(diào)用的函數(shù)和(可選的)作為歸并基礎(chǔ)的初始值。傳給 reduce()和 reduceRight()的函數(shù)接收 4 個參數(shù):前一個值、當前值、項的索引和數(shù)組對象。
這個函數(shù)返回的任何值都會作為第一個參數(shù)自動傳給下一項。第一次迭代發(fā)生在數(shù)組的第二項上,因此第一個參數(shù)是數(shù)組的第一項,第二個參數(shù)就是數(shù)組的第二項。
使用 reduce()方法可以執(zhí)行求數(shù)組中所有值之和的操作,比如:

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

第一次執(zhí)行回調(diào)函數(shù), prev 是 1, cur 是 2。第二次, prev 是 3(1 加 2 的結(jié)果), cur 是 3(數(shù)組的第三項)。這個過程會持續(xù)到把數(shù)組中的每一項都訪問一遍,最后返回結(jié)果。


我的理解
數(shù)組values有5項,所以數(shù)組要執(zhí)行4次運算

(1+2) => 3

(3+3) => 6

(6+4) => 10

(10+5) => 15

那如何證明呢,下面我自己寫的demo

let arr=[1,2,3,4,5]
let sum = arr.reduce((prev,cur,index,array)=>{
        console.log("執(zhí)行了第",index,"次cur的值是",cur,"prev的值是",prev)
        //原來console.log這樣可以用
        return prev+cur
})
console.log(sum)

結(jié)果是

執(zhí)行了第 1 次cur的值是 2 prev的值是 1
執(zhí)行了第 2 次cur的值是 3 prev的值是 3
執(zhí)行了第 3 次cur的值是 4 prev的值是 6
執(zhí)行了第 4 次cur的值是 5 prev的值是 10
15

===>猜想get!!!
===>不過如果用迭代可以怎么做

什么是迭代(才發(fā)現(xiàn)數(shù)據(jù)結(jié)構(gòu)這種東西真的很重要啊,哪里都能用到,js也是!!!) 關(guān)于迭代(我去百度一波....)
定義:一個函數(shù)直接或間接調(diào)用自己
迭代需要滿足的三個條件:

必須有一個明確的中止條件

該函數(shù)所處理的數(shù)據(jù)規(guī)模必須在遞減

這個轉(zhuǎn)化必須是可解的

int sum(int n )
{
    if(n==1) return 1;
    ?else return n+sum(n-1);
}

同樣是求0~n的和,這段代碼是每次在函數(shù)體中調(diào)用自身函數(shù),1~n的和可以拆分成兩個部分,1~n-1的和加上n,因此,遞歸的思想就是:在函數(shù)或子過程的內(nèi)部,直接或者間接地調(diào)用自己的算法,從而把問題轉(zhuǎn)化為規(guī)??s小了的同類問題的子問題

遞歸算法的步驟:

確定遞歸公式,如sum(n) = sum(n-1)+n

確定遞歸結(jié)束條件,如n=1結(jié)束遞歸


剛才的函數(shù)

let arr=[1,2,3,4,5]
let sum = arr.reduce((prev,cur,index,array)=>{
        console.log("執(zhí)行了第",index,"次cur的值是",cur,"prev的值是",prev)
        //原來console.log這樣可以用
        return prev+cur
})
console.log(sum)

就可以理解為

function add(n){
    if(n==1){
        return 1
    }
    return add(n-1)+n
}
console.log(add(5));
當?shù)谝淮螆?zhí)行的時候函數(shù)add(n)碰到add(n-1)的時候就會進入這個函數(shù)執(zhí)行add(n-1),[在這里,我們注意到add(1)=1(就是說遞歸終止)]之后又遇到add(n-1-1),當n=2時 =>
add(2){
  add(2-1)+2 => add(1)+2 => 1+2
}

由此可推

add(3){
  add(2)+3 =>1+2+3
}
add(4){
  add(3)+4 =>1+2+3+4
}
add(5){
  add(4)+5 => 1+2+3+4+5
}

so,這次博客寫完了,謝謝大家閱讀,求點贊求人氣哈哈~~

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/51662.html

相關(guān)文章

  • 關(guān)于Array.reduce理解拓展

    摘要:而則從數(shù)組的最后一項開始,向前遍歷到第一項。傳給和的函數(shù)接收個參數(shù)前一個值當前值項的索引和數(shù)組對象。這個函數(shù)返回的任何值都會作為第一個參數(shù)自動傳給下一項。第二次,是加的結(jié)果,是數(shù)組的第三項。 2018年1月6日 首先我要感謝我的同事徒步上山看日出在我第一份實習的時候?qū)ξ业闹笇?現(xiàn)在我也開始跟他一樣開始養(yǎng)成寫博客的習慣 現(xiàn)在開始討論我遇到的第一個問題,這是我在看javascript高級程...

    李世贊 評論0 收藏0
  • 關(guān)于Array.reduce理解拓展

    摘要:而則從數(shù)組的最后一項開始,向前遍歷到第一項。傳給和的函數(shù)接收個參數(shù)前一個值當前值項的索引和數(shù)組對象。這個函數(shù)返回的任何值都會作為第一個參數(shù)自動傳給下一項。第二次,是加的結(jié)果,是數(shù)組的第三項。 2018年1月6日 首先我要感謝我的同事徒步上山看日出在我第一份實習的時候?qū)ξ业闹笇?現(xiàn)在我也開始跟他一樣開始養(yǎng)成寫博客的習慣 現(xiàn)在開始討論我遇到的第一個問題,這是我在看javascript高級程...

    Karrdy 評論0 收藏0
  • JavaScript數(shù)組迭代(遍歷)方法

    摘要:正文和中新增的的數(shù)組迭代方法如下其中,是新增的,其余都是新增的。指數(shù)組后,返回過濾后的新數(shù)組。它的參數(shù)跟方法是一樣的所有數(shù)組成員依次執(zhí)行回調(diào)函數(shù),直到找出第一個返回值為的成員,然后返回該成員。 前言 ES5和ES6中新增了不少東西,對于數(shù)組而言,新增了不少迭代方法,讓我們可以拋棄for循環(huán),更方便的寫JS代碼。 正文 ES5和ES6中新增的的數(shù)組迭代方法如下: forEach map...

    light 評論0 收藏0
  • 面試題目別有洞天 -> 從es6優(yōu)雅解法,到降級polyfill,再到redux reduce

    摘要:每次被執(zhí)行時,和被傳入,這個根據(jù)進行累加或者是自身消減,英文原意,進而返回最新的。 之前的一篇文章:從一道面試題,到我可能看了假源碼討論了bind方法的各種進階Pollyfill,今天再分享一個有意思的題目。 從解這道題目出發(fā),我會談到數(shù)組的Reduce方法,ES6特性和Redux數(shù)據(jù)流框架中Reducer的命名等等。一道典型的題目,卻如唐代詩人章碣《對月》詩中所云:別有洞天三十六,水...

    econi 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<