LeetCode-python 59.螺旋矩阵 II

题目链接
难度:中等       类型: 数组


给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵。

示例

输入: 3
输出:
[
[ 1, 2, 3 ],
[ 8, 9, 4 ],
[ 7, 6, 5 ]
]

解题思路


按数字递增的方向,坐标值变化的方式为
上:dx=0, dy=1
右:dx=1, dy=0
下:dx=0,dy=-1
左:dx=-1,dy=0

每次拐弯:
dx都变为原来的dy
dy都变为原来的-dx

拐弯的条件:
matrix[x][y]已经有值,对于最外面一圈:matrix[x%n][y%n]有值

代码实现

class Solution(object):
    def generateMatrix(self, n):
        """
        :type n: int
        :rtype: List[List[int]]
        """
        res = [[0]*n for _ in range(n)]
        i, j, di, dj = 0, 0, 0, 1
        for k in range(1, n*n+1):
            res[i][j] = k
            if res[(i+di)%n][(j+dj)%n]:
                di, dj = dj, -di
            i += di
            j += dj
        return res
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 8,973评论 0 2
  • $ \LaTeX{} $历史 $\LaTeX{}$(/ˈlɑːtɛx/,常被读作/ˈlɑːtɛk/或/ˈleɪtɛ...
    大只若于阅读 11,026评论 0 5
  • 事先说明:这是一篇会让人想吐的文章,如果你看到一半感到身体不适,请果断关闭浏览器。 问题提出 在一个以页为单位的信...
    LostAbaddon阅读 4,971评论 21 7
  • TF API数学计算tf...... :math(1)刚开始先给一个运行实例。tf是基于图(Graph)的计算系统...
    MachineLP阅读 9,239评论 0 1
  • public class ImageProcessHelper { ///////////////////////...
    学习不断阅读 7,554评论 0 1

友情链接更多精彩内容