我只是在学习javascript。我对操纵多维数组非常困惑。
var myarr = [
[ 7, 9, 10 ],
[ 6, 9 ],
[ 5, 9 ]
]
我想像这样插入零。在javascript中执行此操作的智能方法是什么
[
[ 7, 9, 10 ],
[ 6, 9, 0 ],
[ 5, 9, 0 ]
]
答案 0 :(得分:2)
您可以首先获得内部数组的最大长度并推送零,直到所有内部数组具有相同的长度。
ViewModel

var myarr = [[7, 9, 10], [6, 9], [5, 9]],
length = myarr.reduce(function (r, a) { return Math.max(r, a.length); }, 0);
myarr.forEach(function (a) {
while (a.length < length) {
a.push(0);
};
});
console.log(myarr);
&#13;
答案 1 :(得分:0)
var myarr = [
[ 7, 9, 10 ],
[ 6, 9 ],
[ 5, 9 ]
]
for(var i = 0; i < myarr.length; i++) {
if(myarr[i].length < myarr.length){
myarr[i].push(0);
}
}
console.log(myarr);
答案 2 :(得分:0)
这是一个解决方案。
var myarr = [
[7, 9, 10],
[6, 9],
[5, 9]
];
var rows = myarr.length;
var cols = 0;
for (var i in myarr) {
if (myarr[i].length > cols)
cols = myarr[i].length;
}
for (i = 0; i < rows; i++) {
for (j = 0; j < cols; j++) {
if (myarr[i][j] == undefined)
myarr[i][j] = 0;
}
}
console.log(myarr);
答案 3 :(得分:0)
var maxLength=0;
for(var i=0;i<myarr.length;i++){
if(myarr[i].length>maxLength){
maxLength=myarr[i].length
}
}
for(var i=0;i<myarr.length;i++){
if(myarr[i].length!=maxLength){
fillZeros(myarr[i])
}
}
function fillZeros(child){
while(child.length!=maxLength)
{child.push(0);}
}
答案 4 :(得分:0)
最好的方法是首先计算你拥有的最长的子阵列长度,然后你可以填充子阵列使它们全部达到相同的长度。
以下内容包括计算最长篇幅的函数,以及用于执行填充的另一函数:
function getMax(arr) {
var max = 0;
for (var i = 0; i < arr.length; i++) {
if (arr[i].length > max)
max = arr[i].length;
}
return max;
}
function pad(arr, max) {
for (var i = 0; i < arr.length; i++) {
for (var j = arr[i].length; j < max; j++)
arr[i].push(0);
}
}
var myarr = [
[7, 9, 10],
[6, 9],
[5, 9]
];
pad(myarr, getMax(myarr));
console.log(myarr);
答案 5 :(得分:0)
看起来你需要一个2维数组的方阵,所以试试这个:
var myarr = [
[7, 9, 10],
[6, 9],
[5, 9, 1, 2, 3, 4, 5, 6, 7] // <--- for example purpose
];
var rows = myarr.length;
var cols = 0;
for(var i = 0; i < myarr.length; i++){
if(myarr[i].length > cols)
cols = myarr[i].length;
}
var limit = rows > cols ? rows : cols;
for(var i = 0; i < limit; i++){
if(myarr[i] == undefined)
myarr[i] = new Array(limit);
for(var j = 0; j < limit; j++){
if(typeof myarr[i][j] == "undefined")
myarr[i][j] = 0;
}
}
for(var i = 0; i < limit; i++){
console.log(JSON.stringify(myarr[i]));
}
答案 6 :(得分:0)
如果你的数组只是一个数字,只能是任意嵌套的填充数组,你可以像我这里一样使用递归函数:
function fillArray(array, val){
for(var i=0; i<array.length; i++){
if(typeof(array[i]) === 'number'){
array[i] = val;
}else{
fillArray(array[i], val);
}
}
}
var test = [5,[3,8,-1,[3,4,5,2,1],[2] ],[[2,2],[3]],[[2,3],[4]],[[2,4],[5]]];
fillArray(test, 0);
答案 7 :(得分:-1)
使用地图功能
var arr = [
[ 7, 9, 10 ],
[ 6, 9],
[ 5, 9]
]
var arr1 = arr.map(function(e){
var arr2 = [];
if(e.length < 3)
e.push(0);
arr2.push(e);
return arr2;
});
alert(arr1);