0x3f 第24天 黑马web (安了半天程序 )hot100普通数组

1.螺旋矩阵

思路太夸张了

用DIRS = (0,1),(1,0),(0,-1),(-1,0)分别表示右下左上三个方向

i+=DIRS[di][0]

j+=DIRS[di][1]

di代表当前的方向di=0时对应的(0,1)i+0,j+1,说明向右走

di = (di+1)%4 右转

核心思路:先构造DIRS元祖,并且想到方向di

从i = 0 j = 0开始遍历

遍历到的做标记

额外引入x,y来做试探,判断是否走到边界,或者重复,这样说明要拐弯了

(如果直接用 i,j 操作,会导致 "移动后发现走不通,再回退" 的冗余逻辑)

i和j的变换逻辑和for循环不同,所以是新颖的赋值

i+=DIRS[di][0]

j+=DIRS[di][1]

时间复杂度 mn 空间复杂度 1

复制代码
class Solution:
    def spiralOrder(self, matrix: List[List[int]]) -> List[int]:
        DIRS = (0,1),(1,0),(0,-1),(-1,0)#右下左上
        i=j=di=0
        m,n = len(matrix),len(matrix[0])
        ans = []
        for _ in range(m*n):
            ans.append(matrix[i][j])
            matrix[i][j] = None  #标记表示走过
            x,y = i+DIRS[di][0],j+DIRS[di][1]#试探步7777
            if x<0 or y<0 or x==m or y==n or matrix[x][y] is None:
                di = (di + 1) % 4
            i+=DIRS[di][0]
            j+=DIRS[di][1]
        return ans

2.旋转图像

1.好理解的方法

先按对角线全部交换

然后每一行反转

这是线代的思路

转置+行翻转

n方 1 但是两次循环

复制代码
class Solution:
    def rotate(self, matrix: List[List[int]]) -> None:
        """
        Do not return anything, modify matrix in-place instead.
        """
        n = len(matrix)
        for i in range(n):
            for j in range(i):
                matrix[i][j],matrix[j][i] = matrix[j][i],matrix[i][j]
        for row in matrix:
            row.reverse()

2.四角转换

每个值都转了90°

核心逻辑:分层 + 四角交换

正方形矩阵旋转的本质是「按层旋转」,每层的元素通过「四个角循环交换」完成旋转:

四角的规律

i,j n-1-j,i n-1-i,n-1-j j,n-1-i

j i j

连接 连接 连接

外循环为了兼容奇数 / 偶数边长,即使出现奇数层,+1//2也能保证这层不用交换

内循环//2说实话没懂原理,死记硬背吧

n方 1 但是一次循环

复制代码
class Solution:
    def rotate(self, matrix: List[List[int]]) -> None:
        """
        Do not return anything, modify matrix in-place instead.
        """
        n = len(matrix)
        for i in range((n+1)//2):
            for j in range(n//2):
                matrix[i][j],matrix[n-1-j][i],matrix[n-i-1][n-1-j],matrix[j][n-i-1]\
                =matrix[n-1-j][i],matrix[n-i-1][n-1-j],matrix[j][n-i-1],matrix[i][j]
相关推荐
weixin_438077492 分钟前
CS336 Assignment 4 (data): Filtering Language Modeling Data 翻译和实现
人工智能·python·语言模型·自然语言处理
小郭团队3 分钟前
未来PLC会消失吗?会被嵌入式系统取代吗?
c语言·人工智能·python·嵌入式硬件·架构
yesyesido3 分钟前
智能文件格式转换器:文本/Excel与CSV无缝互转的在线工具
开发语言·python·excel
Aaron15883 分钟前
全频段SDR干扰源模块设计
人工智能·嵌入式硬件·算法·fpga开发·硬件架构·信息与通信·基带工程
王夏奇6 分钟前
python在汽车电子行业中的应用1-基础知识概念
开发语言·python·汽车
子夜江寒7 分钟前
基于PyTorch的CBOW模型实现与词向量生成
pytorch·python
He_Donglin7 分钟前
Python图书爬虫
开发语言·爬虫·python
求梦8208 分钟前
【力扣hot100题】缺失的第一个正数(12)
数据结构·算法·leetcode
天远Date Lab11 分钟前
Python金融风控实战:集成天远多头借贷行业风险版API实现共债预警
大数据·python
Python极客之家12 分钟前
基于深度学习的刑事案件智能分类系统
人工智能·python·深度学习·机器学习·数据挖掘·毕业设计·情感分析