当前位置:网站首页>螺旋矩阵_数组 | leecode刷题笔记

螺旋矩阵_数组 | leecode刷题笔记

2022-08-04 01:00:00 Begonia_cat

59. 中等螺旋矩阵II

题目:给定一个正整数 n,生成一个包含 1 到 n^2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵。
.
示例:输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, 4 ], [ 7, 6, 5 ] ]
在这里插入图片描述

思路:坚持循环不变量原则,自始至终坚持左闭右开区间可以用range()来实现,range是前开后闭的,进行循环。【图片来自carl哥的代码随想录】
carl代码随想录图片
注意:含有个元素的方形二维数组,其长宽均为n!这个要搞清楚。
代码的第一步是:初始化一个n行n列的二维数组,初始化为全零数组。

当n = 4时:
在这里插入图片描述
当n = 5时:
在这里插入图片描述

四个方向每步各次n-1步,当n为奇数时,二维矩阵有中心点。
数组的下标是从0开始的,所以:
n=3时,中心点的索引为[1,1];
n=5时,中心点的索引为[2,2];
n为奇数时,索引坐标为[n//2, n//2]

从左至右,从上至下,从右至左,总下至上为一次循环,
n=3时,循环1次+1个中心点
n=4时,循环2次
n=5时,循环2次+1个中心点
n=6时,循环3次
循环次数=n//2 + 1个中心点(n为奇数时)
在这里插入图片描述

class Solution:
    def generateMatrix(self, n: int) -> List[List[int]]:
        nums = [[0] * n for _ in range(n)]  # 初始化为n行n列的二维数组
        startx, starty = 0, 0  #起始点为0行0列处
        loop, mid = n//2, n//2  # 迭代次数、n为奇数时,矩阵的中心点
        count = 1  # 计数

        for offset in range(1, loop + 1):
            for i in range(starty, n-offset):  # 从左往右, startx保持不变, starty递增
                nums[startx][i] = count
                count += 1
            for i in range(startx, n-offset):  # 从上至下, starty保持不变,startx递增
                nums[i][n-offset] = count
                count += 1
            for i in range(n-offset, starty, -1):  # 从右至左, startx保持不变,starty递减
                nums[n-offset][i] = count
                count += 1
            for i in range(n-offset, startx, -1):  # 从下至上, starty保持不变,,startx递减
                nums[i][starty] = count
                count += 1
            # 更新起点
            startx += 1
            starty += 1
        if n%2 == 1:  # n为奇数时,填充中心点
            nums[mid][mid] = count
        return nums

54. 中等螺旋矩阵

题目:给你一个 m 行 n 列的矩阵 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]



待更……

原网站

版权声明
本文为[Begonia_cat]所创,转载请带上原文链接,感谢
https://blog.csdn.net/qq_44250700/article/details/126143912