题目要求:
给你一个 m
行 n
列的矩阵 matrix
,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。
示例 1:

输入:matrix = [[1,2,3],[4,5,6],[7,8,9]]
输出:[1,2,3,6,9,8,7,4,5]
示例 2:

输入:matrix = [[1,2,3,4],[5,6,7,8],[9,10,11,12]]
输出:[1,2,3,4,8,12,11,10,9,5,6,7]
代码实现:
int directions[4][2] = {{0, 1}, {1, 0}, {0, -1}, {-1, 0}};//作为方向偏移量
int* spiralOrder(int** matrix, int matrixSize, int* matrixColSize, int* returnSize) {
if (matrixSize == 0 || matrixColSize[0] == 0) {//包含矩阵无元素的情况
*returnSize = 0;
return NULL;
}
int rows = matrixSize, columns = matrixColSize[0];//分别表示矩阵的行数和列数
int visited[rows][columns];//用来标记元素是否被访问
memset(visited, 0, sizeof(visited));
int total = rows * columns;
int* order = malloc(sizeof(int) * total);
*returnSize = total;
int row = 0, column = 0;
int directionIndex = 0;//作为方向索引
for (int i = 0; i < total; i++) {
order[i] = matrix[row][column];
visited[row][column] = true;//访问完标记该位置
int nextRow = row + directions[directionIndex][0], nextColumn = column + directions[directionIndex][1];
if (nextRow < 0 || nextRow >= rows || nextColumn < 0 || nextColumn >= columns || visited[nextRow][nextColumn]) {
directionIndex = (directionIndex + 1) % 4;//控制directionIndex在0~3之间,继续下一个循环
}
row += directions[directionIndex][0];//更新行
column += directions[directionIndex][1];//更新列
}
return order;//返回最终结果
}
作者:力扣官方题解
来源:力扣(LeetCode)
坚持编程,我一直在路上!