Leetcode|48.Rotate Image旋转图像.java

该博客介绍了如何使用Java解决LeetCode第48题——旋转图像。作者提供了两种方法:一是先转置再左右翻转,二是通过旋转四个矩形来实现。文章详细解释了每种方法的思路,并给出了相应的代码实现。
摘要由CSDN通过智能技术生成

题目

给定一个 n × n 的二维矩阵表示一个图像。

将图像顺时针旋转 90 度。

说明:

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

示例 1:

给定 matrix =

[

[1,2,3],

[4,5,6],

[7,8,9]

],

原地旋转输入矩阵,使其变为:

[

[7,4,1],

[8,5,2],

[9,6,3]

]

示例 2:

给定 matrix =

[

[ 5, 1, 9,11],

[ 2, 4, 8,10],

[13, 3, 6, 7],

[15,14,12,16]

],

原地旋转输入矩阵,使其变为:

[

[15,13, 2, 5],

[14, 3, 4, 1],

[12, 6, 8, 9],

[16, 7,10,11]

]

标签

数组;转置

解题思路

方法一:两次旋转–先转置,再左右翻转

最直接的想法是先转置矩阵,然后翻转每一行。这个简单的方法已经能达到最优的时间复杂度O(N2)。

方法二:旋转四个矩形

研究每个元素在旋转的过程中如何移动。

image.png

将给定的矩阵分成四个矩形并且将原问题划归为旋转这些矩形的问题。

image.png

将四个元素作为一个整体进行移动,先将最外围进行旋转,然后逐次到最内层

源自:https://leetcode-cn.com/problems/rotate-image/solution/xuan-zhuan-tu-xiang-by-leetcode/

代码

public class Leetcode48_RotateImage {
   
    public static void main(String[] args) {
   
        int[][] matrix={
   {
   1,2,3,4},{
   5,6,7,8},{
   9,10,11,12},{
   13,14<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦晨涌京

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值