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

每日算法刷题Day2 5.10:leetcode数组1道题3种解法,用时40min

4.LC 旋转矩阵(中等,学习)

面试题 01.07. 旋转矩阵 - 力扣(LeetCode)

思想:

法一:
额外空间数组来回赋值拷贝
法二:
1.翻转90度得到等式a[j][n-i-1]=a[i][j],但是会改变a[j][n-i-1]原始值,再去看该位置变到哪一位置
分析可得,4个位置翻转90度就是4个位置轮换赋值,得到公式
在这里插入图片描述
所以问题变成利用temp变量完成4项原地交换
2.接下来分析i和j的遍历范围,由上述4个位置得,只要遍历1个区域位置即可,所以把正方形划分成4份,取左上角区域,但是不知道n是奇还是偶,所以要分奇偶讨论
在这里插入图片描述
偶数i,j:[0,n/2)
在这里插入图片描述
奇数:i:[0,(n+1)/2),j:[0,n/2) 所以综合可得,i:i:[0,(n+1)/2),j:[0,n/2)
法三:
1.先水平翻转:a[i][j]=a[n-i-1][j],遍历范围:i:[0,n/2),j:[0,n)
2.然后再沿着主对角线翻转:a[i][j]=a[j][i],遍历范围:i:[0,n),j:[0,i)

代码

c++:
法一:

class Solution {
public:void rotate(vector<vector<int>>& matrix) {int n = matrix.size();auto temp = matrix;for (int i = 0; i < n; i++) {for (int j = 0; j < n; j++) {temp[i][j] = matrix[n - j - 1][i];}}matrix = temp;}
};

法二:

class Solution {
public:void rotate(vector<vector<int>>& matrix) {int n = matrix.size();for (int i = 0; i < (n + 1) / 2; i++) {for (int j = 0; j < n / 2; j++) {int temp = matrix[i][j];matrix[i][j] = matrix[n - j - 1][i];matrix[n - j - 1][i] = matrix[n - i - 1][n - j - 1];matrix[n - i - 1][n - j - 1] = matrix[j][n - i - 1];matrix[j][n - i - 1] = temp;}}}
};

法三:

class Solution {
public:void rotate(vector<vector<int>>& matrix) {int n = matrix.size();for (int i = 0; i < n / 2; i++) {for (int j = 0; j < n; j++) {swap(matrix[i][j], matrix[n - i - 1][j]);}}for (int i = 0; i < n; i++) {for (int j = 0; j < i; j++) {swap(matrix[i][j], matrix[j][i]);}}}
};

python:
法一:

class Solution:def rotate(self, matrix: List[List[int]]) -> None:"""Do not return anything, modify matrix in-place instead."""n = len(matrix)temp=[[0]*n for _ in range(n)]# or temp = [row[:] for row in matrix]for i in range(n):for j in range(n):temp[i][j]=matrix[n-j-1][i]matrix[:]=temp

python对象本质是对象的指针,而不是独立存值的容器。
1.替换原始矩阵
a=b;:让a指向b指向的对象,改变a的同时也改变b的内容
所以列表改变值需要:matrix[:]=temp;
2.深拷贝二维列表
temp=matrix[:]只复制了外层,内层仍共享
temp=[[0]*n for _ in range(n)]创建一个新的nxn数组
temp=[row[:] for row in matrix]才深拷贝二维数组matrix
法二:

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 // 2):for j in range((n + 1) // 2):temp = matrix[i][j]matrix[i][j] = matrix[n - j - 1][i]matrix[n - j - 1][i] = matrix[n - i - 1][n - j - 1]matrix[n - i - 1][n - j - 1] = matrix[j][n - i - 1]matrix[j][n - i - 1] = temp

整数除法是//,向下取整
法三:

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 // 2):for j in range(n):matrix[i][j], matrix[n - i - 1][j] = matrix[n - i - 1][j], matrix[i][j]for i in range(n):for j in range(i):matrix[i][j], matrix[j][i] = matrix[j][i], matrix[i][j]

多变量同时赋值

相似题

48. 旋转图像 - 力扣(LeetCode)

http://www.xdnf.cn/news/5250.html

相关文章:

  • MySQL索引详解(上)(结构/分类/语法篇)
  • Excel里面怎样批量去掉字串包含的标点符号
  • Qt解决自定义窗口样式不生效问题
  • 基于ssm+mysql的快递管理系统(含LW+PPT+源码+系统演示视频+安装说明)
  • Linux 离线安装 Docker 和 Docker Compose 最新版 的完整指南
  • 【Linux基础】程序和软件安装管理命令
  • Python爬虫学习路径与实战指南 06
  • Java基础 集合框架 Collection接口和抽象类AbstractCollection
  • Java Spring 常用注解详解
  • 算法-贪婪算法
  • en33网络配置文件未托管
  • 【MyBatis-7】深入理解MyBatis二级缓存:提升应用性能的利器
  • Python核心编程深度解析:作用域、递归与匿名函数的工程实践
  • 17.Excel:实用的 VBA 自动化程序
  • # YOLOv3:深度学习中的目标检测利器
  • linux-----------Ext系列⽂件系统(上)
  • # Java List完全指南:从入门到高阶应用
  • 栈应用:辅助站(c++)
  • C#异步Task,await,async和Unity同步协程
  • 玩转Docker | 使用Docker部署Note Mark笔记应用程序
  • [架构之美]Spring Boot集成MyBatis-Plus高效开发(十七)
  • 求两个正整数的最大公约数和最小公倍数:方法1:辗转相除法
  • 01 | 大模型微调 | 从0学习到实战微调 | AI发展与模型技术介绍
  • STM32实现九轴IMU的卡尔曼滤波
  • 如何在postman使用时间戳
  • Windows下的临界写法
  • 回文数(9)
  • 气象大模型光伏功率预测中的应用:从短期,超短期,中长期的实现与开源代码详解
  • C++GO语言微服务之图片、短信验证码生成及存储
  • 【沉浸式求职学习day35】【Tomcat安装、配置】【Http简述】