【发布时间】:2020-01-16 16:13:11
【问题描述】:
您好,我是新手练习算法,我只是想知道如何解决这个螺旋矩阵挑战:
让函数 MatrixSpiral(strArr) 读取存储在 strArr 中的字符串数组,该数组将表示 2D N 矩阵,并且您的程序应在以顺时针螺旋顺序打印元素后返回元素。您应该将新形成的元素列表作为字符串返回,其中数字用逗号分隔。例如:输入:
["[4, 5, 6, 5]",
"[1, 1, 2, 2]",
"[5, 4, 2, 9]"]
输出:
"4,5,6,5,2,9,2,4,5,1,1,2"
我以前做过简单的矩阵螺旋,但不知道如何解决这样的问题。
这不是一个简单的矩阵螺旋。我尝试使用此代码,但输出方式不同
输入是“字符串数组”的数组(见双引号),输出应该是数字用逗号分隔的字符串。
const spiralOrder = (matrix) => {
if(!matrix.length || !matrix[0].length){
return [];
}
//Use 4 pointes to create wall around square
let rowBegin = 0,
rowEnd = matrix.length - 1,
colBegin = 0,
colEnd = matrix[0].length - 1;
let result = [];
while(rowBegin <= rowEnd && colBegin <= colEnd){
//move right
for(let i= colBegin; i<= colEnd; i++){
result.push(matrix[rowBegin][i]);
}
rowBegin++; // mark row as traversed after moving right
//move down
for(let i=rowBegin; i<= rowEnd; i++){
result.push(matrix[i][colEnd]);
}
colEnd--; //mark column as traversed after moving down
//move left
if(rowBegin <= rowEnd){
for(let i=colEnd; i >= colBegin; i--){
result.push(matrix[rowEnd][i]);
}
}
rowEnd--; //mark end row as traversed after moving left
//move up
if(colBegin <= colEnd){
for(let i=rowEnd; i >= rowBegin; i--){
result.push(matrix[i][colBegin]);
}
}
colBegin++; //mark begining column as traversed after moving up
}
return result;
};
spiralOrder([[4, 5, 6, 5], [1, 1, 2, 2], [5, 4, 2, 9]])
Output: [ '[',
'4',
',',
' ',
'5',
',',
' ',
'6',
',',
' ',
'5',
']',
']',
']',
'9',
' ',
',',
'2',
' ',
',',
'4',
' ',
',',
'5',
'[',
'[',
'1',
',',
' ',
'1',
',',
' ',
'2',
',',
' ',
'2' ]
您能分享任何解决方案吗?
【问题讨论】:
-
@JohnColeman 感谢您的回答。我已经编辑了我的问题。我觉得现在有点不同了。
-
谢谢。大大改进的问题。
标签: javascript algorithm recursion