gpt4 book ai didi

JavaScript - 相同行和列中值的总和

转载 作者:塔克拉玛干 更新时间:2023-11-02 21:15:53 27 4
gpt4 key购买 nike

我有一个包含数字 0 和 1 的 JavaScript 数组,我需要对同一行和同一列中的所有数字求和(如果我想象我的数组是二维的)。我想创建第二个数组,其中包含第一个数组中每个值的总和。

第一项的二维数组可视化(X-Y 值表):
1,1,1,1,1
1,1,1,1,1
1,1,1,1,1
1,1,1,1,1
1,1,1,1,1
(总和:索引 0 处的值 8;0(不包括值本身))

真实数组我有:
1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, 1,1,1,1,1,1,1,1,1
(总和:索引 0 处的值为 8)

第二项的二维数组可视化:
1,1,1,1, 1
1,1,1,1,1
1,1,1,1,1
1,1,1,1,1
1,1,1,1,1

(总和:索引 1 处的值为 8;0)
这样我需要遍历整个数组。

带有零分隔符的第二项的二维数组可视化:
1,1,1,1,1
1,1,1,1,1
1,0,1,1,1
1, 1 ,1,1,1
1, 1 ,1,1,1
(总和:索引 1 处的值为 5;0)
零之后的值我不想算进去。

对于前面的表,结果表应该是这样的...
8,5,8,8,8
8,5,8,8,8
4,x,6,6,6
8,5,8,8,8
8,5,8,8,8

非常感谢您的帮助!

最佳答案

var res = [];  //the 1D array to hold the sums
var hArr = [
[ 1, 1, 1, 1 ],
[ 1, 1, 1, 1 ],
[ 1, 0, 0, 1 ],
[ 1, 1, 0, 0 ]
]; //your array


var vArr = []; //Now lets create an array of arrays with the columns of hArr

for (var j=0; j<hArr[0].length; j++) {
var temp = [];
for (var i=0; i<hArr.length; i++) {
temp.push(hArr[i][j]);
}
vArr.push(temp);
}

//sum all the element in the line - Vertically and Horizontally
function SumVH (hInd, vInd) {
var sum = 0;
//add horizontal elements
//to the left
for(var i=(vInd-1); i>=0; i--) {
//if a 0 is found, break
if (hArr[hInd][i] == 0) {
break;
}
sum += hArr[hInd][i];
}

//to the right
for(var i=(vInd+1); i<hArr[hInd].length; i++) {
//if a 0 is found, break
if (hArr[hInd][i] == 0) {
break;
}
sum += hArr[hInd][i];
}

//add vertical elements
//towards top
for(var i=(hInd-1); i>=0; i--) {
//if a 0 is found, break
if(vArr[vInd][i] == 0) {
break;
}
sum += vArr[vInd][i];
}

//towards bottom
for(var i=(hInd+1); i<vArr[vInd].length; i++) {
//if a 0 is found, break
if(vArr[vInd][i] == 0) {
break;
}
sum += vArr[vInd][i];
}
//console.log("hInd="+hInd+" vInd="+vInd+" Sum="+sum);
return sum;
}

// go through the main array and get result
var sumR = 0;
//sum of each row
for (var i=0; i<hArr.length; i++) {
for (var j=0; j<hArr[i].length; j++) {
sumR = SumVH(i,j);
res.push(sumR);
}
}

请检查它并让我知道它是否像您期望的那样工作。res 变量保存结果。

关于JavaScript - 相同行和列中值的总和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31294579/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com