LeetCode刷题 -- 48. 旋转图像

题目

在这里插入图片描述

算法题解:顺时针旋转矩阵(90度)

1. 算法描述

给定一个 n × n 的二维矩阵,请将矩阵顺时针旋转 90 度。

例如:

输入:

[[1,2,3],[4,5,6],[7,8,9]
]

输出:

[[7,4,1],[8,5,2],[9,6,3]
]

2. 思路分析

顺时针旋转矩阵90度的操作可以分解为两步:

  • 第1步:矩阵转置
    即以矩阵对角线(从左上到右下)为轴,进行镜像翻转。

  • 第2步:每行逆序
    将每一行从左到右逆序。

图示如下:

原矩阵:          转置后:          最终旋转结果:
1 2 3           1 4 7             7 4 1
4 5 6    --->   2 5 8    --->     8 5 2
7 8 9           3 6 9             9 6 3

3. 算法复杂度分析

  • 时间复杂度:O(n²),需要遍历整个矩阵两遍。
  • 空间复杂度:O(1),原地旋转,无需额外空间。

4. 优化后的代码示例(C语言)

/*** @brief 原地顺时针旋转 n×n 矩阵 90 度** @param matrix      二维矩阵指针* @param matrixSize  矩阵的维度 (行数与列数相同)* @param matrixColSize  各行列数(未使用,可忽略或删除)*/
void rotate(int** matrix, int matrixSize, int* matrixColSize) {int i, j, tmp;// 第一步:矩阵转置(沿主对角线翻转)for (i = 0; i < matrixSize; i++) {// 注意:j 从 i 开始,避免元素交换两次for (j = i; j < matrixSize; j++) {tmp = matrix[i][j];matrix[i][j] = matrix[j][i];matrix[j][i] = tmp;}}// 第二步:每行元素逆序(左右翻转)for (i = 0; i < matrixSize; i++) {for (j = 0; j < matrixSize / 2; j++) {tmp = matrix[i][j];matrix[i][j] = matrix[i][matrixSize - j - 1];matrix[i][matrixSize - j - 1] = tmp;}}
}

5. 算法实现注意事项

  • 矩阵为方阵(n×n),否则无法使用该方法。
  • 转置过程中从 j = i 开始遍历,是为防止重复交换已经交换过的元素。

6. 扩展说明(可选)

若需要处理非方阵的矩阵旋转,可以考虑额外开辟空间。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/75489.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vulkan进阶系列1 - Vulkan应用程序结构(完整代码)

一: 概述 在前面的20多篇文章中,我们了解了Vulkan的基础知识,和相关API的使用,接下来我们要从零开始写一套完整Vulkan应用程序,在这个过程中加深对Vulkan中的各种概念的理解。 Vulkan 应用程序一般遵循 初始化 -> 运行循环 -> 资源清理 的结构,本实例也基本遵循了…

VTK的两种显示刷新方式

在类中先声明vtk的显示对象 vtkRenderer out_render; vtkVertexGlyphFilter glyphFilter; vtkPolyDataMapper mapper; // 新建制图器 vtkActor actor; // 新建角色 然后在init中先初始化一下&#xff1a; out_rend…

【CSS3】04-标准流 + 浮动 + flex布局

本文介绍浮动与flex布局。 目录 1. 标准流 2. 浮动 2.1 基本使用 特点 脱标 2.2 清除浮动 2.2.1 额外标签法 2.2.2 单伪元素法 2.2.3 双伪元素法(推荐) 2.2.4 overflow(最简单) 3. flex布局 3.1 组成 3.2 主轴与侧轴对齐方式 3.2.1 主轴 3.2.2 侧轴 3.3 修改主…

详细介绍一下C++的按位运算

在C中&#xff0c;按位运算&#xff08;Bitwise Operations&#xff09; 是直接对二进制位&#xff08;bit&#xff09;进行操作的低级运算&#xff0c;常用于处理硬件、优化性能、加密算法或底层资源管理。以下是按位运算符的详细说明、示例和典型应用场景&#xff1a; 1.按位…

Flask与 FastAPI 对比:哪个更适合你的 Web 开发?

在开发 Web 应用时&#xff0c;Python 中有许多流行的 Web 框架可以选择&#xff0c;其中 Flask 和 FastAPI 是两款广受欢迎的框架。它们各有特色&#xff0c;适用于不同的应用场景。本文将从多个角度对比这两个框架&#xff0c;帮助你更好地选择适合的框架来构建你的 Web 应用…

Python爬虫第一战(爬取优美图库网页图片)

本文是我在学习过程中记录学习的点点滴滴,目的是为了学完之后巩固一下顺便也和大家分享一下,日后忘记了也可以方便快速的复习。 爬取网页图片 前言前言 今天学习的主要是关于如何利用Python爬取网页图片知识的理解和应用 # 1.获取网页信息,交给beautifulsoup # 2.获取页面里…

J1 ResNet-50算法实战与解析

&#x1f368; 本文為&#x1f517;365天深度學習訓練營 中的學習紀錄博客&#x1f356; 原作者&#xff1a;K同学啊 | 接輔導、項目定制 一、理论知识储备 1. 残差网络的由来 ResNet主要解决了CNN在深度加深时的退化问题&#xff08;梯度消失与梯度爆炸&#xff09;。 虽然B…

Python入门(3):语句

目录 1 基本语句 1.1 表达式语句 1.2 赋值语句 2 控制流语句 2.1 条件语句 2.2 循环语句 while循环&#xff1a; for循环&#xff1a; 2.3 流程控制语句 1. break语句&#xff1a;退出整个循环体 2. continue语句&#xff1a;只跳过本次循环&#xff0c;还会进…

浅浅尝试Numpy的函数s:

1.numpy.empty: numpy.empty方法用来创建一个指定形状&#xff08;shape&#xff09;&#xff0c;数据类型&#xff08;dtype&#xff09;且未被初始化的数组&#xff1a; numpy.empty(shape,dtype float,order C) 参数说明&#xff1a; shape:数组形状。 dtype:数据类型&am…

【C++】nlohmann::json 配置加载技术实践:从基础到高级应用

一、nlohmann::json 库概况与核心特性 nlohmann::json 是 C 社区最受欢迎的 JSON 库之一&#xff0c;其设计理念简洁即美&#xff0c;通过单头文件实现完整的 JSON 解析、序列化和操作功能。 1.1 基本特性 nlohmann::json是一个现代C编写的开源JSON库&#xff0c;采用MIT协议…

运算放大器(四)滤波电路(滤波器)

1.滤波电路概述 滤波电路简称滤波器&#xff0c;是一种能使某一部分频率的信号顺利通过&#xff0c;而使其它频率的信号被大幅衰减的电路。 2.滤波器的分类 &#xff08;1&#xff09;低通滤波器&#xff1a;低频信号能够通过&#xff0c;而高频信号不能通过的滤波器称为低通…

mac如何将jar包上传到maven中央仓库中

mac如何将jar包上传到maven中央仓库中 准备sonatype账号 sonatype官网&#xff1a;https://central.sonatype.com/ 建议使用GitHub账号注册&#xff0c;方便 之后选择查看用户信息 选择此选项获取用户token的username与password&#xff0c;建议提前复制一下谨防丢失 之后…

【通知】STM32MP157驱动开发课程全新升级!零基础入门嵌入式Linux驱动,掌握底层开发核心技能!

在嵌入式Linux系统开发中&#xff0c;驱动程序开发是一项关键技术&#xff0c;它作为硬件与软件之间的桥梁&#xff0c;实现了操作系统对硬件设备的控制。相较于嵌入式Linux应用开发&#xff0c;驱动开发由于涉及底层硬件且抽象程度较高&#xff0c;往往让初学者感到难度较大。…

高通将进军英国芯片 IP 业务 Alphawave

高通已确认有意收购高速连接模块设计公司 Alphawave Semi&#xff0c;此举可能会导致又一家英国大型科技公司被外国企业收购。 这家总部位于圣地亚哥的巨头已向伦敦证券交易所提交了一份声明&#xff0c;表示正在与 Alphawave 进行谈判&#xff0c;后者生产用于连接数据中心和…

多模态模型:专栏概要与内容目录

文章目录 多模态模型&#x1f4da; 核心内容模块Stable Diffusion基础教程Stable Diffusion原理深度解析部署与环境配置其他多模态模型实践 多模态模型 &#x1f525; 专栏简介 | 解锁AI绘画与多模态模型的技术奥秘 探索多模态AI技术&#xff0c;掌握Stable Diffusion等流行框…

Vue3 + Element Plus + AntV X6 实现拖拽树组件

Vue3 Element Plus AntV X6 实现拖拽树组件 介绍 在本篇文章中&#xff0c;我们将介绍如何使用 Vue 3 和 Element Plus 结合 antv/x6 实现树形结构的拖拽功能。用户可以将树节点拖拽到图形区域&#xff0c;自动创建相应的节点。我们将会通过简单的示例来一步步讲解实现过程…

cursor的.cursorrules详解

文章目录 1. 文件位置与作用2. 基本语法规则3. 常用规则类型与示例3.1 忽略文件/目录3.2 限制代码生成范围3.3 自定义补全建议3.4 安全规则 4. 高级用法4.1 条件规则4.2 正则表达式匹配4.3 继承规则 5. 示例文件6. 注意事项 Cursor 是一款基于 AI 的智能代码编辑器&#xff0c;…

黑马点评项目总结

redis的key设计规范 推荐规范: 业务前缀数据名称唯一id 比如表示文章点赞的用户集合: blog:like:${blogId} 刷新token有效期(拦截器实现) 使用双重拦截器解耦登录鉴权拦截和刷新有效期 RefreshTokenInterceptor: 拦截所有请求 只负责token续期 没有token则放行 Component p…

Java 大数据在智能安防入侵检测系统中的多源数据融合与分析技术(171)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…