减少和求和阵列位置

时间:2013-02-06 12:46:33

标签: javascript

让我说我有这个阵列:

var likes = [4,7,3,11,3,73,78,34,7,13];

但是,由于某些限制,我只能使用5的长度。所以我希望将它“转换”为5的数组长度,并将其他位置相加,并将它们平均分配。

有人知道我该怎么办?

3 个答案:

答案 0 :(得分:1)

也许这会解决您的问题:

var likes = [4,7,3,11,3,73,78,34,7,13],
    result_array = [ ];

for(var i = 0; i < likes.length; i++)
{
   if(i % 2)
   {
       var new_val = likes[i - 1] + likes[i];
       result_array.push(new_val);
   }
}

查看有效的jsFiddle here

这将导致新数组包含[ 11, 14, 76, 112, 20 ],并且当新值添加到初始数组时,长度也会增加。

答案 1 :(得分:1)

由于不太清楚你想要什么,我也会发一个答案。无论您的输入有多大,此代码都会在输出数组中保持固定长度为5。

var input = [4,7,3,11,3,73,78,34,25,7,13,19,2],
    max = 5,
    out = [];

var adjacentItems = Math.ceil(input.length / max);
for(var i=0; i<input.length; i += adjacentItems) {
    var aSum = 0;
    for(var j=i; j<Math.min(i+adjacentItems, input.length); j++) {
        aSum += input[j];
    }
    out.push(aSum);
}

Check out the fiddle

答案 2 :(得分:0)

最后,我想我找到了答案! :) 如果您有任何建议,请发表评论!

var likes = [1,2,3,4,5,6,7,8,9,10];
    result_array = [];
    result_array2 = [];    
    max = 8;

if (likes.length>max){
    result_array = likes;
    for (var i = 0; i < max; i++) {
            var res = (likes.length - max) / max
            var new_val = (result_array[i] + (result_array[i+1] * res));
            result_array2.push(new_val);

    }

result_array = [];
result_array = result_array2;

}else{
result_array=likes
}

alert(result_array);

请检查代码here