力扣第 54 题 **螺旋矩阵**

力扣第 54 题是 螺旋矩阵 (Spiral Matrix)。题目要求按螺旋顺序遍历一个 m x n 的矩阵,并返回遍历的结果。

解题思路

螺旋矩阵的遍历顺序是 从左到右 ,然后 从上到下 ,接着 从右到左 ,最后 从下到上,依次循环,直到遍历完所有元素。可以通过定义边界条件来控制这些遍历方向:

  1. 定义四个边界 :上边界 top、下边界 bottom、左边界 left 和右边界 right
  2. 按照顺序进行遍历:
    • 从左到右遍历顶行。
    • 从上到下遍历最右列。
    • 从右到左遍历底行(若 top <= bottom)。
    • 从下到上遍历最左列(若 left <= right)。
  3. 每完成一行或一列的遍历后,更新相应的边界。
  4. 重复上述步骤,直到 top > bottomleft > right,即所有元素都被访问。

C 语言实现

c 复制代码
#include <stdio.h>
#include <stdlib.h>

/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* spiralOrder(int** matrix, int matrixSize, int* matrixColSize, int* returnSize) {
    if (matrixSize == 0 || matrixColSize[0] == 0) {
        *returnSize = 0;
        return NULL;
    }

    int top = 0, bottom = matrixSize - 1;
    int left = 0, right = matrixColSize[0] - 1;
    int total = matrixSize * matrixColSize[0];
    
    int* result = (int*)malloc(total * sizeof(int));
    *returnSize = 0;

    while (top <= bottom && left <= right) {
        // 从左到右遍历顶行
        for (int i = left; i <= right; i++) {
            result[(*returnSize)++] = matrix[top][i];
        }
        top++;  // 顶行向下收缩

        // 从上到下遍历最右列
        for (int i = top; i <= bottom; i++) {
            result[(*returnSize)++] = matrix[i][right];
        }
        right--;  // 右列向左收缩

        // 从右到左遍历底行(确保尚未遍历过)
        if (top <= bottom) {
            for (int i = right; i >= left; i--) {
                result[(*returnSize)++] = matrix[bottom][i];
            }
            bottom--;  // 底行向上收缩
        }

        // 从下到上遍历最左列(确保尚未遍历过)
        if (left <= right) {
            for (int i = bottom; i >= top; i--) {
                result[(*returnSize)++] = matrix[i][left];
            }
            left++;  // 左列向右收缩
        }
    }

    return result;
}

int main() {
    int rows = 3, cols = 3;
    int data[3][3] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
    int* matrix[3];
    for (int i = 0; i < rows; i++) {
        matrix[i] = data[i];
    }
    int matrixColSize[] = {3, 3, 3};
    int returnSize;

    int* result = spiralOrder(matrix, rows, matrixColSize, &returnSize);

    printf("螺旋顺序遍历结果: ");
    for (int i = 0; i < returnSize; i++) {
        printf("%d ", result[i]);
    }
    printf("\n");

    free(result);
    return 0;
}

逐步解释代码

  1. 边界初始化 :定义上、下、左、右边界,分别为 top = 0bottom = matrixSize - 1left = 0right = matrixColSize[0] - 1

  2. 循环遍历

    • 从左到右 :遍历顶行,从 leftright,然后将 top 加 1。
    • 从上到下 :遍历最右列,从 topbottom,然后将 right 减 1。
    • 从右到左 (若 top <= bottom):遍历底行,从 rightleft,然后将 bottom 减 1。
    • 从下到上 (若 left <= right):遍历最左列,从 bottomtop,然后将 left 加 1。
  3. 返回结果 :将所有遍历结果存入 result 数组,最终返回螺旋遍历结果。

复杂度分析

  • 时间复杂度 : O ( m ∗ n ) O(m * n) O(m∗n),mn 为矩阵的行数和列数。每个元素被访问一次。
  • 空间复杂度 : O ( m ∗ n ) O(m * n) O(m∗n),存储螺旋顺序的结果数组需要 O ( m ∗ n ) O(m * n) O(m∗n)的空间。
相关推荐
嘻嘻哈哈樱桃5 分钟前
牛客经典101题解题集--贪心算法+模拟
java·python·算法·贪心算法
AKDreamer_HeXY6 分钟前
QOJ 12255 - 36 Puzzle 题解
数据结构·c++·数学·算法·icpc·qoj
AI科技星14 分钟前
《全域数学》第一部 数术本源 第三卷 代数原本第14篇 附录二 猜想证明【乖乖数学】
人工智能·算法·数学建模·数据挖掘·量子计算
Wect28 分钟前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·typescript
憨波个36 分钟前
【说话人日志】DOVER-Lap:overlap-aware diarization 输出融合算法
人工智能·深度学习·算法·音频·语音识别
叼烟扛炮43 分钟前
C++第四讲:类和对象(下)
c++·算法·类和对象
Rabitebla44 分钟前
vector 的骨架:三根指针、模板陷阱与迭代器失效的第一现场
开发语言·数据结构·c++·算法
代码不停1 小时前
BFS解决floodfill算法题目练习
算法·宽度优先
上弦月-编程1 小时前
C语言指针从入门到实战
java·jvm·算法
WL_Aurora1 小时前
Python 算法基础篇之树和二叉树
python·算法