给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素。
示例 1:
输入: [ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7, 8, 9 ] ] 输出: [1,2,3,6,9,8,7,4,5]
示例 2:
输入: [ [1, 2, 3, 4], [5, 6, 7, 8], [9,10,11,12] ] 输出: [1,2,3,4,8,12,11,10,9,5,6,7]
/**
* Note: The returned array must be malloced, assume caller calls free().
*/
int* spiralOrder(int** matrix, int matrixSize, int* matrixColSize, int* returnSize){
if (matrixSize==0){
*returnSize=0;
return NULL;
}
*returnSize=matrixSize*matrixColSize[0];
int *ret=(int *)malloc(sizeof(int)*(*returnSize));
int gap_max=((matrixSize<matrixColSize[0]?matrixSize:matrixColSize[0])+1)/2;
int pos=0;
for(int gap=0;gap<gap_max;gap++)
{
for(int end=matrixColSize[0]-gap,i=gap;i<end;i++)
{//
ret[pos++]=matrix[gap][i];
}
for(int end=matrixSize-gap-1,i=gap+1;i<end;i++)
{
ret[pos++]=matrix[i][matrixColSize[0]-1-gap];
}
if(matrixSize-1-gap!=gap)
{
for(int i=matrixColSize[0]-gap-1;i>=gap;i--)
{
ret[pos++]=matrix[matrixSize-1-gap][i];
}
}
if(matrixColSize[0]-1-gap!=gap)
{
for(int i=matrixSize-2-gap;i>gap;i--)
{
ret[pos++]=matrix[i][gap];
}
}
}
return ret;
}
执行用时 : 0 ms, 在Spiral Matrix的C提交中击败了100.00% 的用户
内存消耗 : 7 MB, 在Spiral Matrix的C提交中击败了50.98% 的用户