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].length1 <= 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
热门推荐
东莞厚街旅游攻略:景点、美食、住宿全攻略
任脉养生揭秘:权威数据见证古中医智慧
中医经络学说:从起源到系统组成
专家报告 | “双高”电力系统:一种新的稳定判据和稳定性分类探讨
汽车冷凝器需要清洗吗?如何清洗?
新手如何学习川崎机器人AS语言
去日本签证怎么办?护照准备有哪些要求?
元宵节为什么要猜灯谜?元宵节猜灯谜的由来和寓意
中华武术步型步法详解:从基础到实战应用
近视也能开飞机,成为飞行员需要几步?
如何探究黄金趋势的分析方法?这种分析方法有哪些实际应用?
全球金霉素龙头涨价反击!股价逆势大涨
蜇伤后刺痛难耐?揭秘天鹅绒蚂蚁“毒液”秘密
你梦见过自己会飞?走进梦的秘密
含高比例新能源的电力系统频率稳定研究综述
日本地少人多,为什么还家家户户都是“别墅”?中国能借鉴吗?
蛋白粉究竟是不是「智商税」?乳清蛋白、大豆蛋白、牛初乳、酪蛋白该怎么选?
不锈钢锅怎么开锅养锅(图文教程)
字体设计之父的创意方法:高桥善丸的设计理念与实践
餐后血糖多少合适?吃饭这样做,巧降餐后血糖
静电:遍及生活角落的神奇效应及应用
住宅小区的安全管理如何加强?这些措施如何提升居民安全感?
减肚腩的3个步骤,坚持90天,练出巧克力般的腹肌!
深入解析:标量、向量与张量的基本概念
变压器温升的影响因素
《情愿》赏析:林徽因的深情绝唱与艺术探索
广东出发值得一去的自驾线路推荐,5条广东自驾到广西最佳线路攻略
职场攻略 | 职场沟通中的 5 个关键技巧,让你的表达更有说服力
春季养生话督脉
婴儿奶粉选购指南:科学喂养的黄金法则