题目描述

给定一个 n × n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。

你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。

作者:力扣 (LeetCode)

链接:https://leetcode-cn.com/leetbook/read/top-interview-questions-easy/xnhhkv/

来源:力扣(LeetCode)

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

 

题目解析

例,输入输出如下图:

这个题目与其说是一道算法题,不如说是一道找规律得题目,我们怎样才能实现图像得90度旋转呢?通过对比输入输出图中数字得位置可以发现:我们可以将第一列得4个数通过顺时针旋转到第一行上,第一行顺时针旋转到最后一列上,一次类推;内圈的数字也要如此旋转,就可以完成题目要求,如下图:

有了思路之后,我们怎么通过算法实现呢?那就是找规律了。

首先,我们以数字5为例,看一下它以及和他有关的数字的变化路径:5->11 11->16 16->15 15->5;

其次,我们继续找规律,我们将上述数字集合线标来一遍:

  • 5(0,0)->11(0,3)

  • 11(0,3)->16(3,3)

  • 16(3,3)->15(3,0)

  • 15(3,0)->5(0,0)

从下标中我们能够发现有重复的下标相互转换数字,那么他们其中有什么内在的连续呢?我们现在找规律已经使用了数字转换流程,数字的下标,仔细想一下我们是不是还有一个关键的变量没有用到,那就是n*n;

最后,我们加上二维数组的行列长度再来一遍:

  • 5([i]:0,[j]:0)->11([i]:0,[n-i或者j-1]:3)

  • 11()

写到第二条的时候我发现写不下去了,这里的下标有大量的0和3,没有办法分辨是i还是j,写出来的规律也不能通用,因此我决定用数字1及其相关的数字类找规律(i=0,j=1)

首先,

  • 1->10

  • 10->12

  • 12->13

  • 13->1

其次,

  • 1(0,1)->10(1,3)

  • 10(1,3)->12(3,2)

  • 12(3,2)->13(2,0)

  • 13(2,0)->(0,1)

最后,

  • 1([i]:0,[j]:1)->10([j]:1,[n-i-1]:3)

  • 10([j]:1,[n-i-1]:3)->12([n-i-1]:3,[n-j-1]:2)

  • 12([n-i-1]:3,[n-j-1]:2)->13([n-j-1]:2,[i]:0)

  • 13([n-j-1]:2,[i]:0)->1([i]:0,[j]:1)

我们找到一下通用变量,有兴趣的可以套一下数字9及其相关数字的规律:

令:int m=n-i-1,c=n-j-1。

如下图示:

 

题目解答

算法1,时间复杂度为 o(n²),直接上代码如下:

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

解题思路:解题思路再题目分析中已经详细阐明,此次不再累述。

LeetCode:旋转图像的更多相关文章

  1. LeetCode:旋转图像【48】

    LeetCode:旋转图像[48] 题目描述 给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使 ...

  2. 前端与算法 leetcode 48. 旋转图像

    目录 # 前端与算法 leetcode 48. 旋转图像 题目描述 概要 提示 解析 解法一:转置加翻转 解法二:在单次循环中旋转 4 个矩形 算法 传入测试用例的运行结果 执行结果 GitHub仓库 ...

  3. LeetCode——48. 旋转图像

    给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使用另一个矩阵来旋转图像. 示例 1: 给定 m ...

  4. LeetCode初级算法之数组:48 旋转图像

    旋转图像 题目地址:https://leetcode-cn.com/problems/rotate-image/ 给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: ...

  5. [LeetCode] Rotate Image 旋转图像

    You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwise). ...

  6. LeetCode 48. Rotate Image(旋转图像)

    You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwise). ...

  7. python(leetcode)-48旋转图像

    给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使用另一个矩阵来旋转图像. 示例 1: 给定 m ...

  8. LeetCode(48):旋转图像

    Medium! 题目描述: 给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使用另一个矩阵来旋转 ...

  9. Leetcode题库——48.旋转图像

    @author: ZZQ @software: PyCharm @file: rotate.py @time: 2018/11/16 15:41 要求:给定一个 n × n 的二维矩阵表示一个图像.将 ...

随机推荐

  1. JVM:垃圾收集器与对象的"存活"问题

    垃圾收集器垃圾收集(Garbage Collection,GC).当需要排查各种内存溢出.内存泄露问题时,当垃圾收集成为系统更高并发量的瓶颈时,我们需要去了解GC和内存分配. 检查对象的"存 ...

  2. Vivado Synth/Place Faild但是没有给出error信息

    最近遇到一个现象,以前可以编译通过的工程,修改之后发现Synthesis编译报错,而且没有给出error信息,以前也出现过无故place 失败但是没有给出error信息的现象,查看错误日志输出文件,出 ...

  3. palindrome-partitioning leetcode C++

    Given a string s, partition s such that every substring of the partition is a palindrome. Return all ...

  4. shell 脚本控制命令的执行顺序

    &&,||,(),{},& 五个符号的运用shell脚本执行命令的时候,有时候会依赖于前一个命令是否执行成功.而&&和||就是用来判断前一个命令执行效果的. 也 ...

  5. element-UI 中的upload组件如何添加token?

    <el-upload :show-file-list="false" :on-error="errmsg" :headers="headers& ...

  6. 【数据结构&算法】10-串基础&KMP算法源码

    目录 前言 串的定义 串的比较 串的抽象类型数据 串与线性表的比较 串的数据 串的存储结构 串的顺序存储结构 串的链式存储结构 朴素的模式匹配算法 模式匹配的定义 朴素的匹配方法(BRUTE FORC ...

  7. mybatis插入数据时处理为null的属性

    在做项目的时候,数据库中的所有字段被设置为全都不能为null,但是在我们开发过程中,插入一些记录的时候,实体类中的一些字段如果页面没有传入,则默认就会被设置为null,这样的话,在执行插入语句的时候, ...

  8. Ubuntu安装BCC

    Ubuntu安装BCC 教程 官方文档 安装 这里官方文档中首先讲到的是二进制文件的安装,直接通过apt进行安装 sudo apt-get install bpfcc-tools linux-head ...

  9. Spring IOC&DI 控制反转和依赖注入

    控制反转(Inversion of Control,缩写为IOC),它是把你设计好的对象交给spring控制,而不再需要你去手动 new Object(); 网上对于IOC的解释很多,对程序员而言,大 ...

  10. 全球首发-基于.NET 6长线支持Zoomla!逐浪CMS v8.6.0正式发布

    传送门: https://www.z01.com/down/3778.shtml 全新Zoomla!逐浪CMS v8.6.0 全于首个基于.net 6长线支持的CMS-Zoomla!逐浪CMS v8. ...