力扣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

相关推荐
DoraBigHead1 小时前
小哆啦解题记——映射的背叛
算法
Heartoxx1 小时前
c语言-指针与一维数组
c语言·开发语言·算法
孤狼warrior1 小时前
灰色预测模型
人工智能·python·算法·数学建模
京东云开发者1 小时前
京东零售基于国产芯片的AI引擎技术
算法
chao_7892 小时前
回溯题解——子集【LeetCode】二进制枚举法
开发语言·数据结构·python·算法·leetcode
十盒半价3 小时前
从递归到动态规划:手把手教你玩转算法三剑客
javascript·算法·trae
GEEK零零七3 小时前
Leetcode 1070. 产品销售分析 III
sql·算法·leetcode
凌肖战3 小时前
力扣网编程274题:H指数之普通解法(中等)
算法·leetcode
秋说3 小时前
【PTA数据结构 | C语言版】将数组中元素反转存放
c语言·数据结构·算法
WebInfra3 小时前
如何在程序中嵌入有大量字符串的 HashMap
算法·设计模式·架构