Leetcode 旋转图像

解题思路:

  1. 转置矩阵:通过将矩阵的行列互换来实现转置操作。
  2. 水平翻转矩阵:通过将每行的数据进行对称交换,从而完成90度旋转。

通过这两个步骤,矩阵就会顺时针旋转90度。

cpp 复制代码
class Solution {
public:
    void rotate(vector<vector<int>>& matrix) {
        int n = matrix.size();

        //先转置矩阵
        for(int i = 0; i < n; ++i) {
            //j 的初始值是从 i 开始,而不是从 0 开始,这是为了避免重复交换已经处理过的元素。
            // j从i 开始只会对矩阵的上三角区域进行转置操作,避免了不必要的重复交换
            for(int j = i; j < n; ++j) { 
                swap(matrix[i][j], matrix[j][i]);
            }
        }
        //然后水平翻转每一行
        for(int i = 0; i < n; ++i) {
            for(int j = 0; j < n / 2; ++j) {
                swap(matrix[i][j], matrix[i][n - 1 - j]); // n - 1是因为下标从 0 开始, 下标 n 取不到 
            }
        }
    }
};
相关推荐
通信小呆呆3 分钟前
Hankel结构及其快速算法详解
线性代数·算法·机器学习
四代水门3 分钟前
服务端倒带(Server-Side Rewind)命中判定系统
java·前端·算法
吃好睡好便好4 分钟前
矩阵的左除和右除
人工智能·学习·线性代数·算法·矩阵
江屿风10 分钟前
C++图的基本概念流食般投喂-竞赛编
开发语言·数据结构·c++·笔记·算法·图论
Halo_tjn13 分钟前
JDBC 技术的使用
java·算法
Byte不洛16 分钟前
哈希表原理 + 冲突解决 + C++实现
数据结构·c++·算法·哈希算法·散列表
Dillon Dong3 小时前
【风电控制】TI TMS320F28379D 双CPU架构解析与任务分布设计
嵌入式硬件·算法·变流器·风电控制
小羊在睡觉9 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
3DVisionary9 小时前
蓝光三维扫描:医疗制造的精度焦虑怎么解
人工智能·算法·制造·蓝光三维扫描·医疗制造·三维检测·义齿检测
jiayong239 小时前
面试中遇到不熟悉问题的应对策略深度解析
面试·职场和发展