码迷,mamicode.com
首页 > 其他好文 > 详细

旋转图像

时间:2021-02-09 11:47:06      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:输出   tar   选择   bsp   个数   load   target   题目   tco   

此博客链接:

旋转图像

题目链接:https://leetcode-cn.com/problems/rotate-image/

题目

给定一个 n × n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 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]]
示例 3:

输入:matrix = [[1]]
输出:[[1]]
示例 4:

输入:matrix = [[1,2],[3,4]]
输出:[[3,1],[4,2]]

 

题解

此题旋转90度后的数字和旋转前的数字的差别在于,把第一个数放倒第一行的最后一个数的位置,第一行的最后一个数放倒最后一列的最下面,也就是把外围矩形的角的数字轮询交换,把角旁边的数字也是轮询交换,在角旁边的数字轮询交换时,如果把矩形分为左下三角形和右上三角形,以两个三角形的对称轴交换数组重点额数字,在把第一列和最后一列交换的结果和把矩形选择90度的结果是一样的。

代码

class Solution {
    public void rotate(int[][] matrix) {
        for(int i=0;i<matrix.length;i++)   
        {
            for(int j=0;j<matrix[0].length;j++)
            {
                if(i!=j&j<i)
                {
                 
                   int temp=matrix[i][j];
                   matrix[i][j]=matrix[j][i];
                   matrix[j][i]=temp;
                }
            }
        } 
           for(int i=0;i<matrix.length;i++)   
        {
            for(int j=0;j<matrix[0].length/2;j++)
            {

                int temp=matrix[i][j];
                matrix[i][j]=matrix[i][matrix[0].length-1-j];
                matrix[i][matrix[0].length-1-j]=temp;
            }
        }
      
    }
}

 

结果

技术图片

 

旋转图像

标签:输出   tar   选择   bsp   个数   load   target   题目   tco   

原文地址:https://www.cnblogs.com/ping2yingshi/p/14387373.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!