【Golang】LeetCode 54. 螺旋矩阵

54. 螺旋矩阵

题目描述

思路

实际上解决这道题目并不需要什么特别的思路,只需要按照题目的规则进行模拟即可。

具体来说,我们可以设置四个变量,分别表示当前我们遍历到的螺旋矩阵的子矩阵的起始行 / 终止行 / 起始列 / 终止列,我们将变量命名为u / d / l / r。此处仅举对第一行进行遍历的例子:当我们开始对第一行进行遍历时,实际上我们要遍历的是matrix[u][l...r]这个区间,将这个区间当中的数值都加入到答案的数组当中即可。在完成这一行的遍历之后,我们需要对子矩阵的范围进行调整,规则也非常的明显,那就是把表示矩阵上边界的变量u进行自增。边界条件是当u > d时,代表矩阵已经完成了遍历,此时对最外层循环进行break并返回答案即可。

对子矩阵的左右边界以及下边界进行遍历同理。

基于以上思路,我们来写代码解决问题。

Golang 题解

go 复制代码
func spiralOrder(matrix [][]int) []int {
    m, n := len(matrix), len(matrix[0])
    l, r, u, d := 0, n - 1, 0, m - 1
    
    ans := []int{}
    for {
        for i := l; i <= r; i ++ {
            ans = append(ans, matrix[u][i])
        }
        u ++
        if u > d {
            break
        }

        for i := u; i <= d; i ++ {
            ans = append(ans, matrix[i][r])
        }
        r --
        if l > r {
            break
        }

        for i := r; i >= l; i -- {
            ans = append(ans, matrix[d][i])
        }
        d --
        if u > d {
            break
        }

        for i := d; i >= u; i -- {
            ans = append(ans, matrix[i][l])
        }
        l ++
        if l > r {
            break
        }
    }

    return ans
}

Python 题解

python 复制代码
class Solution:
    def spiralOrder(self, matrix: List[List[int]]) -> List[int]:
        l, r, u, d = 0, len(matrix[0]) - 1, 0, len(matrix) - 1
        
        ans = []
        while True:
            i = l
            while i <= r:
                ans.append(matrix[u][i])
                i += 1
            u += 1
            if u > d:
                break
            
            i = u
            while i <= d:
                ans.append(matrix[i][r])
                i += 1
            r -= 1
            if l > r:
                break

            i = r
            while i >= l:
                ans.append(matrix[d][i])
                i -= 1
            d -= 1
            if u > d:
                break
            
            i = d
            while i >= u:
                ans.append(matrix[i][l])
                i -= 1
            l += 1
            if l > r:
                break

        return ans
相关推荐
05候补工程师9 小时前
【408狂飙·数据结构】核心考点深度复盘:数组地址计算、特殊矩阵压缩存储与树的五大性质解题直觉
数据结构·笔记·线性代数·考研·算法·矩阵
青山师9 小时前
HashMap深度解析:哈希冲突、扩容机制与线程安全
算法·安全·哈希算法·java面试·hashmap源码
货拉拉技术9 小时前
私域转化率翻倍的秘密:我们把多模态Agent融进了私域营销
人工智能·算法·设计模式
WL_Aurora9 小时前
备战蓝桥杯国赛【Day 17】
算法·蓝桥杯
kcuwu.9 小时前
决策树与集成学习深度解析:从原理到实践
算法·决策树·集成学习
programhelp_10 小时前
2026 Fall Coinbase Software Engineer OA 真题分享与通关指南
算法
CQU_JIAKE10 小时前
5.19【A】
算法
数智工坊10 小时前
【FDA论文阅读】: 傅里叶域自适应——零训练成本的语义分割无监督域适配方法
论文阅读·人工智能·学习·算法·自动驾驶
承渊政道10 小时前
【贪心算法】(经典实战应用解析(五):单调递增的数字、坏了的计算器、合并区间、⽆重叠区间、⽤最少数量的箭引爆⽓球)
数据结构·c++·leetcode·贪心算法·排序算法·动态规划·哈希算法
2601_9577875810 小时前
矩阵流量转化漏斗拆解:从公域获客到私域成交的技术链路设计
线性代数·矩阵