力扣hot100之螺旋矩阵

python 复制代码
class Solution:
    def spiralOrder(self, matrix: List[List[int]]) -> List[int]:
        # 用四个数对应4个遍历的方向[0, 1, 2, 3] - [右,下,左,上]
        go_state = 0 # 起始必须向右
        # record_matrix = [[0] * n for _ in range(m)]
        n_0, n_1, n_2, n_3 = 0, 0, 0, 0
        m, n = len(matrix), len(matrix[0])  
        go_num, limit_num = 0, len(matrix) * len(matrix[0])
        ans = []
        i, j = 0, 0
        while go_num < limit_num :
            ans.append(matrix[i][j])
            # record_matrix[i][j] = 1
            go_num += 1
            if go_state == 0:
                if j == n - 1 - n_1:
                    go_state = 1
                    i += 1
                    n_0 += 1
                else:
                    j += 1
            elif go_state == 1:
                if i == m - 1 - n_2:
                    go_state = 2                        
                    j -= 1
                    n_1 += 1
                else:
                    i += 1
            elif go_state == 2:
                if j == n_3:
                    go_state = 3                        
                    i -= 1
                    n_2 += 1
                else:
                    j -= 1
            else:
                if i == n_1:
                    go_state = 0                        
                    j += 1
                    n_3 += 1
                else:
                    i -= 1
        return ans
                       

个人解法:

1.用4个状态标记遍历的走向

2.当前状态的结束状态依赖于下一个状态的完全执行次数

3.用遍历的元素数量作为退出循环的临界

大佬们的解法:

这种解法和大佬的方法二思路一致,其方法一则将当前状态以及该状态下对当前坐标的动作融合起来了,可以参考:https://leetcode.cn/problems/spiral-matrix/solutions/2966229/liang-chong-fang-fa-jian-ji-gao-xiao-pyt-4wzk

相关推荐
Fly Wine4 小时前
Leetcode之有效字母异位词
算法·leetcode·职场和发展
程序员夏末5 小时前
【LeetCode | 第七篇】算法笔记
笔记·算法·leetcode
csdn_aspnet6 小时前
C/C++ 两个凸多边形之间的切线(Tangents between two Convex Polygons)
c语言·c++·算法
数据皮皮侠6 小时前
中国城市间地理距离矩阵(2024)
大数据·数据库·人工智能·算法·制造
3GPP仿真实验室6 小时前
深度解析基站接收机核心算法:从 MRC 到 IRC 的空间滤波演进
算法
Boop_wu6 小时前
[Java 算法] 动态规划(1)
算法·动态规划
WolfGang0073216 小时前
代码随想录算法训练营 Day18 | 二叉树 part08
算法
TK云大师-KK6 小时前
TikTok自动化直播遇到内容重复问题?这套技术方案了解一下
大数据·运维·人工智能·矩阵·自动化·新媒体运营·流量运营
ryrhhhh7 小时前
多平台同步优化技术:矩阵跃动小陌GEO如何实现一次配置、全端搜索曝光
人工智能·线性代数·矩阵
hanlin037 小时前
刷题笔记:力扣第43、67题(字符串计算)
笔记·算法·leetcode