LeetCode 算法: 旋转图像c++
创作时间:
作者:
@小白创作中心
LeetCode 算法: 旋转图像c++
引用
CSDN
1.
https://blog.csdn.net/yanceyxin/article/details/139637278
在算法面试和编程练习中,LeetCode是一个不可或缺的平台。本文将详细讲解LeetCode上一道经典的图像处理题目:旋转图像。通过学习本文,你将掌握如何使用辅助数组法实现图像的顺时针旋转90度,并通过具体的C++代码示例加深理解。
题目描述
给定一个 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
解题思路
要将一个 n × n 的二维矩阵(代表一个图像)顺时针旋转 90 度,你可以遵循以下解题思路:
- 理解问题:首先,理解顺时针旋转90度意味着什么。对于矩阵中的每个元素,它将移动到原始位置的左上角方向。
- 创建新矩阵:由于旋转后的矩阵大小不会改变,你可以使用与原始矩阵相同大小的新矩阵来存储结果。
- 遍历原始矩阵:遍历原始矩阵的每个元素,确定它们在新矩阵中的位置。对于矩阵中的每个元素
matrix[i][j]
,它将在新矩阵中的位置是new_matrix[j][n-1-i]
。 - 填充新矩阵:按照上述规则,将原始矩阵的元素复制到新矩阵的相应位置。
- 优化空间:如果不需要保留原始矩阵,你可以在原地修改矩阵以节省空间。这可以通过先交换行,然后反转每一行来实现。
- 代码实现:根据上述逻辑,编写代码实现矩阵的旋转。
- 测试:编写测试用例来验证你的解决方案是否正确。确保测试包括各种大小的矩阵,包括特殊情况,如 n=1 或 n=2。
- 考虑边界条件:确保你的解决方案能够处理矩阵的边界条件,例如矩阵的第一行和第一列。
- 性能分析:分析你的解决方案的时间和空间复杂度。理想情况下,时间复杂度应该是 O(n^2),因为每个元素都被访问一次,空间复杂度应该是 O(1),如果原地旋转的话。
- 代码优化:如果可能,尝试优化你的代码,使其更简洁或提高性能。
这种方法不需要额外的空间,因为它直接在原始矩阵上进行操作。但请注意,这种方法会修改原始矩阵,如果需要保留原始矩阵,则需要先复制一份。
复杂度分析
- 时间复杂度:O(n^2),因为需要遍历整个矩阵。
- 空间复杂度:O(n^2),因为使用了额外的矩阵存储旋转后的结果。
C++代码实现
#include <iostream>
#include <vector>
using namespace std;
void rotateMatrix(vector<vector<int>>& matrix) {
int n = matrix.size();
vector<vector<int>> newMatrix(n, vector<int>(n));
// 将原始矩阵的元素复制到新矩阵中
for (int i = 0; i < n; ++i) {
for (int j = 0; j < n; ++j) {
newMatrix[j][n - 1 - i] = matrix[i][j];
}
}
// 将新矩阵赋值回原始矩阵
matrix = newMatrix;
}
void printMatrix(const vector<vector<int>>& matrix) {
for (const auto& row : matrix) {
for (int val : row) {
cout << val << " ";
}
cout << endl;
}
}
int main() {
vector<vector<int>> matrix = {
{1, 2, 3},
{4, 5, 6},
{7, 8, 9}
};
cout << "Original Matrix:" << endl;
printMatrix(matrix);
rotateMatrix(matrix);
cout << "Rotated Matrix:" << endl;
printMatrix(matrix);
cout << endl;
vector<vector<int>> matrix2 = {
{5, 1, 9, 11},
{2, 4, 8, 10},
{13, 3, 6, 7 },
{15, 14, 12, 16}
};
cout << "Original Matrix2:" << endl;
printMatrix(matrix2);
rotateMatrix(matrix2);
cout << "Rotated Matrix2:" << endl;
printMatrix(matrix2);
return 0;
}
- 输出结果:
Original Matrix:
1 2 3
4 5 6
7 8 9
Rotated Matrix:
7 4 1
8 5 2
9 6 3
Original Matrix2:
5 1 9 11
2 4 8 10
13 3 6 7
15 14 12 16
Rotated Matrix2:
15 13 2 5
14 3 4 1
12 6 8 9
16 7 10 11
热门推荐
实木门安装步骤与验收规范详解
限仓制度对投资市场的影响与重要性分析
新武器加入,解放军海军陆战队战力将提升多少?
“二十四节气歌”其实有八句,您可能没唱全
面向动态防伪应用的荧光电泳显示器件
上海原油期货趋势分析报告
云南古城美食探秘:从鸡豆凉粉到过桥米线
揭秘电信诈骗:为什么我们容易上当受骗?
关于儿童测量体温的那些事儿
中国篮球运动员,巅峰实力如何排名?
火影:当男忍者们留起长发,药师兜变成甜妹,佐助和鸣人变身御姐
1928年,张作霖出殡,规模宏大,孝子跪地,关东军假意前来悼念,当年发生了什么?
数九歌:冬日里的智慧与温情
2024年建筑工程行业五大挑战、七大趋势与四大应对之策解析
过度午睡有五大风险!三类人群最好不午睡
股骨颈骨折康复,6种简单方法分享
个性化还款策略:对个人财务状况、信用评分和生活的影响
石油输出国组织(OPEC):全球能源市场的关键玩家
中山大学团队开发新型IBD治疗系统,实现“菌群-免疫-炎症”多靶点协同治疗
能不能长寿,先查心率?专家透露:55岁后,心率别超这个数字
闭环思维:职场人必备的重要素养
海南代表委员为人才工作建言献策
新质生产力蜀山行 | 可视科学:用可视化技术诠释科学之美
装修油漆施工全流程详解:从乳胶漆到木材油漆的施工要点
为什么要设置任务优先级?如何设置?
指数移动平均线交易策略:从计算到实战应用
蜜袋鼯如何洗澡
电商物流优化:传统零售配送体系的智能升级方案
新国标来了!电动自行车行业将迎来哪些变化?
漫步塞上老街,触摸“塞外青城”的传承与新生