54.螺旋矩阵(中等)

给你一个 mn 列的矩阵 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]

提示:

  • m == matrix.length
  • n == matrix[i].length
  • 1 <= m, n <= 10
  • -100 <= matrix[i][j] <= 100
python 复制代码
class Solution:
    def spiralOrder(self, matrix: List[List[int]]) -> List[int]:
        left,right,top,below=0,len(matrix[0])-1,0,len(matrix)-1
        res=[]
        while True:
            for i in range(left,right+1): res.append(matrix[top][i])
            top+=1
            if top>below: break
            for i in range(top,below+1): res.append(matrix[i][right])
            right-=1
            if left>right: break
            for i in range(right,left-1,-1): res.append(matrix[below][i])
            below-=1
            if top>below: break
            for i in range(below,top-1,-1): res.append(matrix[i][left])
            left+=1
            if left>right: break
        return res
        

主要思想是设立上下左右四个边界,根据边界打印,打印完之后边界向内收缩1,表示已打印,如果边界相遇说明打印已完成。

首先在第一行开始从左到右打印,打印完第一行之后,上边界下移,也就是top加一,然后从上边界开始从上到下打印,打印完后右边界左移,然后从右边界从右到左打印,下边界上移,然后从下边界从下到上打印,一直如此循环。

打印行的时候只需要看上边界是否大于下边界,如果大于就退出,表示打印完了;同样打印列的时候看左边界是否大于右边界,大于就退出。

模拟过程:

假设矩阵是 3行3列

复制代码
matrix = [
    [1, 2, 3],
    [4, 5, 6],
    [7, 8, 9]
]

初始:l=0, r=2, t=0, b=2

第一轮循环:

  1. 从左到右:res.append(matrix[0][0..2])[1,2,3]

  2. t += 1t=1

  3. 从上到下:res.append(matrix[1..2][2])[1,2,3,6,9]

  4. r -= 1r=1

  5. 从右到左:res.append(matrix[2][1..0])[1,2,3,6,9,8,7]

  6. b -= 1b=1

  7. 从下到上:res.append(matrix[1..0][0])[1,2,3,6,9,8,7,4]

  8. l += 1l=1

此时边界:l=1, r=1, t=1, b=1

第二轮循环开始:

  1. 从左到右:res.append(matrix[1][1..1])[1,2,3,6,9,8,7,4,5]

  2. t += 1t=2

  3. 检查 if t > b: break

    • 现在 t=2, b=1

    • 2 > 1成立 ✅

    • break 退出循环

相关推荐
小雨下雨的雨2 小时前
井字棋AI机器人实现详解 - Minimax算法实战-鸿蒙PC Electron框架完成
前端·人工智能·算法·华为·electron·鸿蒙
xieliyu.5 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
一条小锦吕*5 小时前
基于Spring Boot + 数据可视化 + 协同过滤算法的推荐系统设计与实现(源码+论文+部署全讲解)
spring boot·算法·信息可视化
如竟没有火炬7 小时前
最大矩阵——单调栈
数据结构·python·线性代数·算法·leetcode·矩阵
8Qi87 小时前
LeetCode 1143 & 718:最长公共子序列 / 最长重复子数组
算法·leetcode·职场和发展·动态规划
绿算技术8 小时前
万卡推理集群存储选型分析:从核心架构到应用视角
大数据·科技·算法·架构
想吃火锅10058 小时前
【leetcode】1.两数之和js版
javascript·算法·leetcode
net3m339 小时前
一阶软件低通滤波器算法
人工智能·算法
水木流年追梦10 小时前
大模型入门-大模型优化方法12-YaRN 长文本外推技术
人工智能·分布式·算法·正则表达式·prompt