如何解决reduce 方法中的累加器值如何在不显式更改的情况下更改?
这是我第一次在这里写东西,所以提前道歉。
我很确定我很好地掌握了 reduce() 方法,但我似乎无法特别围绕一个概念。在这个特定问题中,我们被要求找到所有数组参数共享的元素。我能够用 reduce 方法构建一个答案。我知道它有效,而且我知道有更有效的解决方案,但我似乎无法理解累加器值如何自行修改,即使我没有重新分配它的值。
让我解释一下:在作为第二个数组的当前值的第一次迭代之后,我检查当前元素是否与我的累加器(第一个数组)共享共性。在检查公共值并将其推入结果后,results = [5,15,7]
。下一次迭代开始时的累加器值也成为我的结果值集,但同样,我没有明确地重新分配累加器值,例如 acc = results
。没有显式更改,累加器如何“理解”更改?我有点只是按原样接受了这种机制,但希望得到解释。如果我应该提供更多说明,请告诉我。谢谢!
function intersection(arrays) {
return arrays.reduce((acc,curr) => {
// here,acc = the first array --> 5,7 --> 15,5
let results = []
for(let element of curr) {
if(acc.includes(element)) results.push(element)
}
// here,results = 5,5 --> 15,5
return results
})
}
const arr1 = [5,10,20,7,3];
const arr2 = [15,88,1,5,21];
const arr3 = [1,21];
console.log(intersection([arr1,arr2,arr3]));
// should log: [5,15]
解决方法
看到这个基本版本的reduce,你可能会更好地理解它,它在调用时简单地对数组值求和
Array.prototype.myReduce = function(callback,start) {
// inital value of acc is start value `0` set in call
let acc = start;
this.forEach((elem,i) => {
// acc gets assigned the return value from the callback
// every iteration of this internal loop
acc = callback(acc,elem,i,this)
});
// then finally gets returned from the outer function
return acc
};
const arr = [1,2,3]
const res = arr.myReduce((a,c,arr) => {
return a + c // returned to `acc` in the forEach loop above
},0)
console.log('Result:',res) // expect 1+2+3 = 6
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。