zoukankan      html  css  js  c++  java
  • 旋转图像

    此博客链接:

    旋转图像

    题目链接: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;
                }
            }
          
        }
    }

    结果

    出来混总是要还的
  • 相关阅读:
    Python:三元运算
    SaltStack部署服务及配置管理apache+php-第二篇
    SaltStack介绍及简单配置-第一篇
    git基础常用维护命令
    MySQL设置只读模式
    运维杂记-05
    Tomcat的配置,设置内存,获取用户IP
    Linux系统巡检项目
    Redis维护
    nginx配置文件说明
  • 原文地址:https://www.cnblogs.com/ping2yingshi/p/14387373.html
Copyright © 2011-2022 走看看