import java.util.ArrayList;
public class Solution {
public ArrayList<Integer> spiralOrder(int[][] matrix) {
int m = matrix.length;
ArrayList<Integer> arrayList = new ArrayList<>();
if (0 == m) {
return arrayList;
}
if (1 == m) {
for (int i : matrix[0]) {
arrayList.add(i);
}
return arrayList;
}
int n = matrix[0].length;
if (1 == n) {
for (int i = 0; i < m; i++) {
arrayList.add(matrix[i][0]);
}
return arrayList;
}
int startRow = 0;
int endRow = m - 1;
int startColumn = 0;
int endColumn = n - 1;
while (arrayList.size() < m * n) {
for (int i = startColumn; i <= endColumn; i++) {
arrayList.add(matrix[startRow][i]);
}
startRow++;
if (arrayList.size() == m * n) {
break;
}
for (int i = startRow; i <= endRow; i++) {
arrayList.add(matrix[i][endColumn]);
}
endColumn--;
if (arrayList.size() == m * n) {
break;
}
for (int i = endColumn; i >= startColumn; i--) {
arrayList.add(matrix[endRow][i]);
}
endRow--;
if (arrayList.size() == m * n) {
break;
}
for (int i = endRow; i >= startRow; i--) {
arrayList.add(matrix[i][startColumn]);
}
startColumn++;
}
return arrayList;
}
}