我们说我有这个:
function arrSum(){
*code here*
}
如何编写arrSum函数,使其可以对多维数组(可变深度)中的所有整数求和。
即
arrSum([2, 5, [4, 6], 5]) === 22;
我知道某处必须有答案,但我真的无法找到它。如果这是重复,请告诉我。
答案 0 :(得分:8)
只需用递归
编写这样的函数
function arrSum(arr) {
var sum = 0;
// iterate array using forEach, better to use for loop since it have higher performance
arr.forEach(function(v) {
// checking array element is an array
if (typeof v == 'object')
// if array then getting sum it's element (recursion)
sum += arrSum(v);
else
// else adding the value with sum
sum += v
})
// returning the result
return sum;
}
console.log(arrSum([2, 5, [4, 6], 5]) === 22);

使用for
循环
function arrSum(arr) {
var sum = 0;
for (var i = 0; i < arr.length; i++) {
if (typeof arr[i] == 'object')
sum += arrSum(arr[i]);
else
sum += arr[i];
}
return sum;
}
console.log(arrSum([2, 5, [4, 6], 5]) === 22);
&#13;
答案 1 :(得分:3)
使用.reduce()
的更现代的方法:
const arr = [2, 5, [4, 6], 5];
const arrSum = array =>
array.reduce(
(sum, num) => sum + (Array.isArray(num) ? arrSum(num) : num * 1),
0
);
console.log(arrSum(arr));
&#13;
答案 2 :(得分:1)
检查一下:
function arrSum(objArr){
var total = 0;
for(var outerLoop=0; outerLoop < objArr.length; outerLoop++){
if(objArr[outerLoop].constructor === Array){
for(var innerLoop=0; innerLoop < objArr[outerLoop].length; innerLoop++){
total += objArr[outerLoop][innerLoop];
}
} else {
total += objArr[outerLoop];
}
}
return total;
}
alert (arrSum([2, 5, [4, 6], 5]));
答案 3 :(得分:1)
function arrSum(arr) {
var totalSum = null;
var numString = arr.toString();
var numberArray = numString.split(",");
numberArray.forEach(function(ele){
totalSum = totalSum + parseInt(ele);
});
return totalSum;
}
console.log(arrSum([2, 5, [4, 6], 5]);
答案 4 :(得分:1)
如果我们有一个包含字符串和整数的多维数组,并且我们必须得到数字的总和,那么在@Pranav C Balan的解决方案之后,我们可以在else循环中添加一个检查以仅检查下面的数字 -
function arrSum(arr) {
var sum = 0;
for (var i = 0; i < arr.length; i++) {
if (typeof arr[i] == 'object'){
sum += arrSum(arr[i]);
}else if (Number(arr[i])){
sum += arr[i];
}
}
return sum;
}
console.log(arrSum([2, 'a', 5, [4, 6, 10, [1, 2, 'b'], 10], 5]));
答案 5 :(得分:0)
我会构建一个类似于 Pranav C Balan 的函数,区别在于我会在调用isObject()
之前检查forEach()
,
通过这种方式,我可以通过发送单个 numeric
参数或Null
值来解决问题。
function arrSum(v) {
// checking if element is an array
if (typeof v == 'object') {
var sum = 0;
// iterate array using forEach, better to use for loop since it have higher performance
v.forEach(function(e) {
sum+=arrSum(e);
});
return sum;
}
else {
return v;
}
}
$('body').append($('<p></p>').html('[2, 5, [4, 6], 5] = ' + arrSum([2, 5, [4, 6], 5])));
$('body').append($('<p></p>').html('[2,, 5] = ' + arrSum([2,, 5])));
$('body').append($('<p></p>').html('5 = ' + arrSum(5)));
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
&#13;
答案 6 :(得分:0)
这可以通过lodash _.flattenDeep
和_.sum
完成:
var arr = [2, 5, [4, 6], 5];
arrSum(arr);
function arrSum(arr) {
var arrFlattens = _.flattenDeep(arr);
// => [2, 5, 4, 6, 5]
console.log(_.sum(arrFlattens));
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.11/lodash.min.js"></script>
答案 7 :(得分:0)
为什么没有人使用 flat()
?
const arr = [2, 5, [4, 6], 5];
const result = arr.flat().reduce((a,b) => a+b);
console.log(result);