【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解

LeetCode 48. 旋转图像 | C++ 矩阵变换最优解

📌 题目描述

题目级别:中等

给定一个 n × n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。

你必须在 原地 (In-place) 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要使用另一个矩阵来旋转图像。


💡 解题思路:矩阵镜像变换法

直接寻找旋转 90 度后的坐标映射关系 (i, j) -> (j, n-1-i) 并进行原地四元组交换比较复杂。

一个更直观、更不容易出错的方法是将旋转分解为两次简单的镜像变换:

1. 沿主对角线转置 (Transpose)

遍历矩阵的左下三角或右上三角,交换 matrix[i][j]matrix[j][i]

  • 效果:行变成了列。
  • 代码特征for (int i = 0; i < n; i++) 内嵌 for (int j = 0; j < i; j++)

2. 左右翻转 (Reverse Rows)

对转置后的矩阵,将每一行进行反转(首尾交换)。

  • 效果:将列的顺序调转,最终完成顺时针旋转。
  • 代码特征 :可以使用 std::reverse(matrix[i].begin(), matrix[i].end()) 或双指针交换。

💻 C++ 代码实现

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

        // 1. 转置矩阵:沿主对角线翻转
        // 注意 j 的范围是 0 到 i,只处理一半,否则换过去又换回来了
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < i; j++) {
                swap(matrix[i][j], matrix[j][i]);
            }
        }

        // 2. 左右翻转:对每一行执行 reverse
        for (int i = 0; i < n; i++) {
            // 使用双指针进行行内反转
            for (int j = 0, k = n - 1; j < k; j++, k--) {
                swap(matrix[i][j], matrix[i][k]);
            }
            // 提示:也可以直接调用 std::reverse(matrix[i].begin(), matrix[i].end());
        }
    }
};
相关推荐
Ricky_Theseus3 小时前
C++右值引用
java·开发语言·c++
吴梓穆4 小时前
UE5 c++ 常用方法
java·c++·ue5
云栖梦泽4 小时前
Linux内核与驱动:9.Linux 驱动 API 封装
linux·c++
Morwit4 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展
py有趣4 小时前
力扣热门100题之岛屿的数量(DFS/BFS经典题)
leetcode·深度优先·宽度优先
SpiderPex4 小时前
第十七届蓝桥杯 C++ B组-题目 (最新出炉 )
c++·职场和发展·蓝桥杯
炘爚4 小时前
C++ 右值引用与程序优化
开发语言·c++
si莉亚5 小时前
ROS2安装EVO工具包
linux·开发语言·c++·开源
智者知已应修善业5 小时前
【51单片机单按键切换广告屏】2023-5-17
c++·经验分享·笔记·算法·51单片机