题目描述
输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10.
分析:
1、从外向里顺时针打印,从模型上看,这就像洋葱模型,一层一层的剥皮。 大家由此联想到了什么呢? 首先引入脑海的是不是递归呢?
2、通过递归算法,我们可以将关注点放在最外面那层顺时针打印即可。其它的,依靠递归即可完成。
如此题目的意图就简化成对第一层顺时针打印的实现。 这样题目的复杂度是不是降到很低了呢? 我们只需要关注几个关键的边界条件判断,就可以解决所有的问题。
3、如何实现剥皮呢,我们知道js中提供了splice方法,可以对数组进行增删改成,它会连带着索引一起删除,用它作为“剥皮”的工具方法最合适不过了。
4、将矩阵分为上、右、下、左四个部分
递归法:
function printMatrix(matrix)
{
let result = [];
// 递归终止条件
if(matrix.length === 0 || matrix[0].length === 0){
return [];
}
if(matrix.length === 1 && matrix[0].length === 1){
result.push(matrix[0][0]);
return result;
}
// 剥掉上部分
for(let i = 0;i < len1; i++){
result.push(matrix[0][0]);
matrix[0].splice(0,1);
}
matrix.splice(0,1);
// 剥掉右部分
for(let i = 0; i < len2; i++){
result.push(matrix[i][matrix[i].length - 1]);;
matrix[i].splice(matrix[i].length - 1, matrix[i].length);
}
// 剥掉下部分
let len3 = matrix[matrix.length - 1].length;
if(len3 === 0){
return result;
}
for(let i = 0; i< len3; i++){
let lastRow = matrix.length - 1;
let lastColumn = matrix[lastRow].length - 1;
result.push(matrix[lastRow][lastColumn]);
matrix[lastRow].splice(lastColumn, lastColumn+1);
}
matrix.splice(matrix.length - 1, matrix.length);
// 剥掉左部分
for(let i =0; i< len4;i++){
result.push(matrix[matrix.length - 1 - i][0])
matrix[matrix.length - 1 - i].splice(0, 1)
}
// 递归调用
return [...result, ...printMatrix(matrix)];
}
其他经典答案:
function printMatrix(matrix)
{
// write code here
var row=matrix.length;
var col=matrix[0].length;
var res=[];
if(row==0||col==0){
return res;
}
var left=0,
top=0,
right=col-1,
bottom=row-1;
while(left<=right&&top<=bottom){
for(var i=left;i<=right;i++)
res.push(matrix[top][i]);
for(var i=top+1;i<=bottom;i++)
res.push(matrix[i][right]);
if(top!=bottom)
for(var i=right-1;i>=left;i--)
res.push(matrix[bottom][i]);
if(left!=right)
for(var i=bottom-1;i>top;i--)
res.push(matrix[i][left]);
left++,top++,right--,bottom--;
}
return res;
}