目录
螺旋矩阵
描述
给定一个m x n大小的矩阵(m行,n列),按螺旋的顺序返回矩阵中的所有元素。
示例1
输入:
[[1,2,3],[4,5,6],[7,8,9]]
返回值:
[1,2,3,6,9,8,7,4,5]
方法:遍历
按照一圈一圈逐圈螺旋进行遍历
import java.util.*;
public class Solution {
public ArrayList<Integer> spiralOrder(int[][] matrix) {
ArrayList<Integer> list=new ArrayList<>();
if (matrix.length==0) return list;
int top=0,bottom=matrix.length-1;
int left=0,right=matrix[0].length-1;
while(true){
//从左上至右上
for (int i = left; i <= right; i++) {
list.add(matrix[top][i]);
}
top=top+1;
if (top>bottom) break;
//从右上至右下
for (int i = top; i <= bottom; i++) {
list.add(matrix[i][right]);
}
right=right-1;
if (left>right) break;
//从右下至左下
for (int i = right; i >= left; i--) {
list.add(matrix[bottom][i]);
}
bottom=bottom-1;
if (top>bottom) break;
//从左下至左上
for (int i = bottom; i >= top; i--) {
list.add(matrix[i][left]);
}
left=left+1;
if (left>right) break;
}
return list;
}
}
时间和空间消耗如下: