题目:
思路:
参考:https://blog.csdn.net/ShiXiAoLaNga/article/details/124975293
上下左右,四个游标,代表边界,每次遍历完一行或一列都移动游标;直到 down > up、right < left,边界条件,则循环结束;
注意:这题在写的过程中非常容易出错,要特别小心边界条件。
代码:
public List<Integer> spiralOrder(int[][] matrix) {
int rows = matrix.length;
int columns = matrix[0].length;
int left = 0, right = columns - 1;
int up = 0, down = rows - 1;
List<Integer> result = new ArrayList<>();
while (true) {
// 向右走
for (int i = left; i <= right; i++) {
result.add(matrix[up][i]);
}
// 消掉头部一行
if (++up > down) {
break;
}
// 向下走
for (int i = up; i <= down; i++) { // 注意起始条件i=up,不是i=0
result.add(matrix[i][right]);
}
// 消掉右侧一列
if (--right < left) {
break;
}
// 向左走
for (int j = right; j >= left; j--) { // 注意边界条件 j>=left 不是j>=0
result.add(matrix[down][j]);
}
// 消掉最下面一行
if (--down < up) { // 这里是--down
break;
}
// 向上走
for (int j = down; j >= up; j--) {
result.add(matrix[j][left]);
}
// 消掉左侧一列
if (++left > right) {
break;
}
}
return result;
}