首页
学习
活动
专区
圈层
工具
发布

☆打卡算法☆LeetCode 48、旋转图像 算法解析

一、题目 1、算法题目 “给定一个二维矩阵表示一个图像,将图像顺时针旋转90°,返回旋转后的图像矩阵。” 题目链接: 来源:力扣(LeetCode) 链接:48....旋转图像 - 力扣(LeetCode) (leetcode-cn.com) 2、题目描述 给定一个 n × n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。...你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。...13,3,6,7],[15,14,12,16]] 输出:[[15,13,2,5],[14,3,4,1],[12,6,8,9],[16,7,10,11]] 二、解题 1、思路分析 这道题,首先分析题目,将二维矩阵图像进行旋转...对称的只要旋转一半即可。

44220

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

题目描述: 给定一个 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] ], 原地旋转输入矩阵...[14, 3, 4, 1], [12, 6, 8, 9], [16, 7,10,11] ] 思路一: 矩阵转置+镜像翻转 这个题拿过来的第一个思路,就是矩阵转置和镜像水平翻转, 类似下面的图像...这是旋转90度,如果逆时针旋转90或者是多少度的时候,也最好先从第一个思路开始出发,看看能不能简单的转置加逆序搞定,搞不定的时候,再考虑第二种思路。

2.3K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    旋转图像

    01 题目描述 给定一个 n × n 的二维矩阵表示一个图像。 将图像顺时针旋转 90 度。 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要使用另一个矩阵来旋转图像。...03 两次反转 第二种方式就反转和旋转数组一题一样我们直接观察输入图与目标图通过怎样的变换可以得到 ? 旋转90度的关系肯定是没有直接方式的,这里我们肯定是用到的设值。...04 总结 总体来说都是一个原地算法,时间也都是O(n^2),像这一题与之前一题都是属于数组内原地的变化位置即多值交换以及换成多组反转即两值交换的组合。...这些题主要也是体会在数组这样的数据结构当中我们可以有的算法思想:遍历、逆序、原地交换、快慢指针。...万变不离其中,那么从更新《LeetCode日常》系列开始到这篇为止LeetCode初级算法合集中的数组篇章完结即将开启下一篇章字符串相关算法

    1.8K30

    图像旋转

    问题描述 试题编号: 201503-1 试题名称: 图像旋转 时间限制: 5.0s 内存限制: 256.0MB 问题描述: 问题描述   旋转是图像处理的基本操作,在这个问题中...,你需要将一个图像逆时针旋转90度。   ...计算机中的图像表示可以用一个矩阵来表示,为了旋转一个图像,只需要将对应的矩阵旋转即可。 输入格式   输入的第一行包含两个整数n, m,分别表示图像矩阵的行数和列数。   ...接下来n行每行包含m个整数,表示输入的图像。 输出格式   输出m行,每行包含n个整数,表示原始矩阵逆时针旋转90度后的矩阵。...package geekfly.test; import java.util.Scanner; public class 图像旋转 { public static void main(String

    1.5K10

    数据结构与算法-1 :旋转图像

    全文字数:1794字 全文配图:4 图 全文阅读时间:5min 前言 从本文开始,我将开启一个新的系列文章的编写数据结构与算法,在本系列文章中,我将对牛客、LeetCode等主流算法刷题平台的精彩题目进行讲解...,实现语言包括Python(主)、Javascript、C、C++,同时我也会将相关算法与我们的实际开发项目结合,帮助大家更好的理解这略显枯燥的算法。...【LeetCode】题目描述 给定一个 n × n 的二维矩阵表示一个图像。将图像顺时针旋转 90 度。说明:你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵。...请不要使用另一个矩阵来旋转图像。...示例1: 给定 matrix = [ [1,2,3], [4,5,6], [7,8,9] ], 原地旋转输入矩阵,使其变为: [ [7,4,1], [8,5,2], [9,6,3

    85330

    【CCF】图像旋转

    本文链接:https://blog.csdn.net/weixin_42449444/article/details/84949588 试题编号: 201503-1 试题名称: 图像旋转 时间限制:...5.0s 内存限制: 256.0MB 问题描述: 问题描述   旋转是图像处理的基本操作,在这个问题中,你需要将一个图像逆时针旋转90度。   ...计算机中的图像表示可以用一个矩阵来表示,为了旋转一个图像,只需要将对应的矩阵旋转即可。 输入格式   输入的第一行包含两个整数n, m,分别表示图像矩阵的行数和列数。   ...接下来n行每行包含m个整数,表示输入的图像。 输出格式   输出m行,每行包含n个整数,表示原始矩阵逆时针旋转90度后的矩阵。...80分代码: #include using namespace std; int main() { int row,col; //图像矩阵的行数和列数

    99310

    图像处理: 无损地旋转图像

    OpenCV自带的旋转图像方法 (有损) 原图像: 如果用OpenCV自带cv2.warpAffine接口来实现图片旋转: import cv2 # 读取原图像 img = cv2.imread.../rotated_img.jpg", rotated_img) 处理后的结果: 可以明显看出,原图像左右两边的像素信息(黄色框内)全部丢失,损失严重: 无损旋转 我自己想到了一种无损旋转的方法.../girl.jpg") 获取输入图像的信息,生成旋转操作所需的参数: h, w = img.shape[:2] padding = (w - h) // 2 center = (w // 2, w...= cv2.warpAffine(img_padded, M, (w, w)) 从旋转后的图片中截取出我们需要的部分,作为最终的输出图像: output = rotated_padded[:,.../girl.jpg") cv2.imshow("", img) cv2.waitKey(1000) # 获取输入图像的信息,生成旋转操作所需的参数(padding: 指定零填充的宽度; canter:

    3K30

    旋转图像

    题目描述 给定一个 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...事实上有一个更加巧妙的做法,我们可以巧妙地利用对称轴旋转达到我们的目的,如图,我们先进行一次以对角线为轴的翻转,然后 再进行一次以水平轴心线为轴的翻转即可。 ?...这种做法的时间复杂度是O(n^2) ,空间复杂度是O(1) 关键点解析 矩阵旋转操作 代码 /* * @lc app=leetcode id=48 lang=javascript * * [48] Rotate

    92720
    领券