当前位置: 首页 > article >正文

LeetCode 48 Rotate Image 解题思路和python代码

题目:
You are given an n x n 2D matrix representing an image, rotate the image by 90 degrees (clockwise).

You have to rotate the image in-place, which means you have to modify the input 2D matrix directly. DO NOT allocate another 2D matrix and do the rotation.

Example 1:
在这里插入图片描述
Input: matrix = [[1,2,3],[4,5,6],[7,8,9]]
Output: [[7,4,1],[8,5,2],[9,6,3]]

Example 2:
在这里插入图片描述
Input: matrix = [[5,1,9,11],[2,4,8,10],[13,3,6,7],[15,14,12,16]]
Output: [[15,13,2,5],[14,3,4,1],[12,6,8,9],[16,7,10,11]]

Constraints:

n == matrix.length == matrix[i].length
1 <= n <= 20
-1000 <= matrix[i][j] <= 1000

解题思路:
首先,转置这个matrix。

[[1, 2, 3],
 [4, 5, 6],
 [7, 8, 9]]

转置后变成:

[[1, 4, 7],
 [2, 5, 8],
 [3, 6, 9]]

接着,把 matrix 中的每一行都reverse。

[[7, 4, 1],
 [8, 5, 2],
 [9, 6, 3]]

完成将 matrix 旋转90°。

转置矩阵的 time complexity 是O(n^2),
reverse矩阵中每一行的 time complexity 也是 O(n^2)。

整体的 time complexity 是O(n^2)。
space complexity 是 O(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, n):
                matrix[i][j], matrix[j][i] = matrix[j][i], matrix[i][j]

        for i in range(n):
            matrix[i].reverse()

        return matrix


http://www.kler.cn/news/339774.html

相关文章:

  • Java第二阶段---12继承---第一节 继承
  • OpenAI 推出 Canvas 工具,助力用户与 ChatGPT 协作写作和编程
  • 和鲸科技创始人范向伟:拐点即将来临,AI产业当前的三个瓶颈
  • 十款超好用的图纸加密软件推荐!2024企业图纸加密最佳选择!
  • Python绘制--绘制心形曲线
  • 分布式事务讲解 - 2PC、3PC、TCC
  • C#来执行SolidWorks的VBA宏代码:来自粉丝的答疑贴
  • 解决Element-ui input 在搜狗输入法下,限制输入数字时先输入汉字后无法绑定的问题
  • 数据结构 ——— 单链表oj题:环状链表(求出环的入口节点)
  • Spring与Spring Boot之间的区别
  • HTML 什么是块级元素?
  • AI产品经理面试,背烂这100个问题就稳了
  • flatten-maven-plugin统一版本打包失败问题记录
  • 为确保阻塞缺陷的解决时间要求得到有效执行,可以采取以下措施:
  • 开放原子开源基金会网站上的开源项目EasyBaaS存在内存泄露缺陷
  • GPT-SOVIT模型部署指南
  • 【python实操】python小程序之封装(登录、小明)
  • linux中的火墙优化策略
  • 生成哈夫曼树
  • Python国庆作业