力扣第 54 题: 螺旋矩阵

题目描述

力扣第 54 题 ------ 螺旋矩阵,要求从矩阵的左上角开始,按顺时针方向逐层遍历矩阵中的所有元素,并以一维数组的形式返回结果。

解题思路

这道题可以用模拟法解决,通过维护矩阵的边界(上下左右四个方向)来实现螺旋顺序的输出。


代码实现与逐行详解

c 复制代码
int* spiralOrder(int** matrix, int matrixSize, int* matrixColSize, int* returnSize) {
  1. 函数签名 :返回一维数组形式的螺旋矩阵结果。
    • matrix: 输入矩阵,二维数组。
    • matrixSize: 矩阵的行数。
    • matrixColSize: 矩阵每行的列数数组。
    • returnSize: 返回数组的大小。
c 复制代码
    if (matrixSize == 0 || matrixColSize[0] == 0) {
        *returnSize = 0;
        return NULL;
    }
  1. 边界判断 :如果矩阵为空,直接返回 NULL
c 复制代码
    *returnSize = matrixSize * matrixColSize[0];
    int* result = (int*)malloc(sizeof(int) * (*returnSize));
    if (!result) {
        return NULL;  // 内存分配失败
    }
  1. 初始化结果数组:根据矩阵总元素数量分配动态内存。
c 复制代码
    int left = 0, right = matrixColSize[0] - 1, top = 0, bottom = matrixSize - 1;
    int index = 0;
  1. 定义边界变量 leftrighttopbottom,以及当前输出位置的索引 index

螺旋遍历逻辑
c 复制代码
    while (index < *returnSize) {
  1. 通过 while 循环逐步缩小矩阵边界,输出所有元素。

  • 从左到右遍历
c 复制代码
        for (int i = left; i <= right && index < *returnSize; i++) {
            result[index++] = matrix[top][i];
        }
        top++;
  1. 从左到右遍历当前 top 行,将该行的元素加入结果,并向下收缩 top 边界。

  • 从上到下遍历
c 复制代码
        for (int i = top; i <= bottom && index < *returnSize; i++) {
            result[index++] = matrix[i][right];
        }
        right--;
  1. 从上到下遍历当前 right 列,加入结果,并向左收缩 right 边界。

  • 从右到左遍历
c 复制代码
        for (int i = right; i >= left && index < *returnSize; i--) {
            result[index++] = matrix[bottom][i];
        }
        bottom--;
  1. 从右到左遍历当前 bottom 行,加入结果,并向上收缩 bottom 边界。

  • 从下到上遍历
c 复制代码
        for (int i = bottom; i >= top && index < *returnSize; i--) {
            result[index++] = matrix[i][left];
        }
        left++;
  1. 从下到上遍历当前 left 列,加入结果,并向右收缩 left 边界。

返回结果
c 复制代码
    return result;
}
  1. 最终返回结果数组。

主函数测试

c 复制代码
int main() {
    // ...(省略,见完
    整代码部分)
}

测试用例中定义了一个 3 × 4 3 \times 4 3×4 的矩阵,程序会输出其螺旋顺序:1 2 3 4 8 12 11 10 9 5 6 7


复杂度分析

  • 时间复杂度 : O ( m ⋅ n ) O(m \cdot n) O(m⋅n),其中 m m m 是矩阵行数, n n n 是矩阵列数。每个元素被遍历一次。
  • 空间复杂度 : O ( m ⋅ n ) O(m \cdot n) O(m⋅n),用于存储结果数组。

输出结果

text 复制代码
螺旋矩阵输出结果:
1 2 3 4 8 12 11 10 9 5 6 7
相关推荐
AI成长日志8 小时前
【笔面试算法学习专栏】图算法入门专题:岛屿数量与课程表
学习·算法·面试
中科院提名者8 小时前
RAG 与向量检索的底层算法
人工智能·算法
雅俗共赏1008 小时前
傅里叶变换、短时傅里叶变换、小波变化对比
算法
旺仔.2919 小时前
顺序容器:forward list单链表 详解
数据结构·c++·list
vx_biyesheji00019 小时前
计算机毕业设计:Python汽车数据分析系统 Django框架 requests爬虫 可视化 车辆 数据分析 大数据 机器学习(建议收藏)✅
爬虫·python·算法·机器学习·django·汽车·课程设计
MicroTech20259 小时前
微算法科技(NASDAQ:MLGO)后量子区块链安全架构:基于模块化格密码的抗量子签名机制
科技·算法·区块链
米粒19 小时前
力扣算法刷题 Day 24
算法·leetcode·职场和发展
郝学胜-神的一滴9 小时前
从线程栈到表达式求值:栈结构的核心应用与递归实现
开发语言·数据结构·c++·算法·面试·职场和发展·软件工程
月落归舟9 小时前
排序算法---(二)
数据结构·算法·排序算法
sonnet-10299 小时前
交换排序算法
java·c语言·开发语言·数据结构·笔记·算法·排序算法