当前位置: 首页 > news >正文

LeetCode刷题系列 -- 48. 旋转图像

给定一个 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]]

提示:

  • n == matrix.length == matrix[i].length

  • 1 <= n <= 20

  • -1000 <= matrix[i][j] <= 1000

48. 旋转图像 - 力扣(Leetcode)

思路

1. 先将矩阵按照对角线折叠,上角元素与左下角元素交换
2. 将矩阵左右交换
这样的转换原因:旋转90度的话,那就是需要将行与列转换。然后,再想办法转为预期矩阵

c++:

class Solution {
public:void rotate(vector<vector<int>>& matrix) {// 1. 沿着对角线将元素折叠,右上角元素与左下角元素交换int n = matrix.size();for(int i=0; i<n; i++) {for(int j=i+1; j<n; j++) {int tmp = matrix[i][j];matrix[i][j] = matrix[j][i];matrix[j][i] = tmp;}}// 2. 将矩阵左右交换for(int i=0; i<n; i++) {int left = 0;int right = n-1;while(left < right) {int tmp = matrix[i][left];matrix[i][left] = matrix[i][right];matrix[i][right] = tmp;left++;right--;}}}
};

http://www.lryc.cn/news/1338.html

相关文章:

  • 在多线程环境下使用哈希表
  • 【排序算法】堆排序(Heap Sort)
  • 分类预测 | Matlab实现SSA-RF和RF麻雀算法优化随机森林和随机森林多特征分类预测
  • Allegro如何添加ICT操作指导
  • 软件架构设计(二)——领域架构、基于架构的软件开发方法
  • 数组常用方法(2)---数组遍历方法
  • 卸载Node.js
  • 发表计算机SCI论文,会经历哪些过程? - 易智编译EaseEditing
  • python中lambda的用法
  • 网络安全协议(3)
  • 102.第十九章 MySQL数据库 -- MySQL的备份和恢复(十二)
  • 【C++】C++入门 类与对象(一)
  • 笔记_js运算符
  • java面试题(十九) Mybatis
  • Linux系统位运算函数以及相应CPU ISA实现收录
  • logback配置文件---logback.xml
  • Web前端-设计网站公共header
  • 引用和指针傻傻分不清
  • MySQL面试题:关系型数据库SQL和非关系型数据库NoSQL
  • 1.Redis【介绍与安装】
  • DataStore快速上手1-preference
  • 彻底掌握 MySQL InnoDB 的锁机制
  • C++继承
  • 动态代理是基于什么原理?
  • YOLO-V4经典物体检测算法介绍
  • angular相关知识点总结
  • 大坝安全监测系统:水库“守坝人”!
  • CentOS7安装配置OpenVNP连接远端服务器
  • 04- Matplotlib数据可视化详解 (数据库)
  • 高性能MySQL -- 查询性能优化