题目描述 输入一个行和列为n和m的矩阵,再输入一个只包含1、2的大小不超过10000000的数字,表示要将矩阵进行变化,使用数位分离,从个位开始,如果是1则顺时针旋转 , 如果是2则逆时针旋转 ,然后十位数字,百位数字,千位数字,以此类推,全部操作完后,输出变化后的矩阵例如:输入 3 2 1 2 3 4 5 6 21 ,则输出: 1 2 3 4 5 6 输入描述 n+2行,第一行包含两个正整数 n和m,表示矩阵的行数和列数。 第2-n+1行,每行m个整数。 第n+2行,输入一个只包含1、2的不超过10000000的数字 输出描述 输出变化后的矩阵 用C++解
时间: 2023-12-28 14:05:03 浏览: 78
题目还是比较简单的,可以用一个函数来完成对矩阵的旋转操作。具体实现可以参考以下代码:
```cpp
#include <iostream>
#include <vector>
using namespace std;
void rotate(vector<vector<int>>& matrix, int direction) {
int n = matrix.size();
int m = matrix[0].size();
int cnt = 0;
for (int k = 1; k <= n / 2; k++) {
int i = k - 1, j = k - 1;
int tmp = matrix[i][j];
while (j < m - k) {
matrix[i][j] = matrix[i][j + 1];
j++;
cnt++;
if (cnt % 10 == direction) {
return;
}
}
while (i < n - k) {
matrix[i][j] = matrix[i + 1][j];
i++;
cnt++;
if (cnt % 10 == direction) {
return;
}
}
while (j > k - 1) {
matrix[i][j] = matrix[i][j - 1];
j--;
cnt++;
if (cnt % 10 == direction) {
return;
}
}
while (i > k - 1) {
matrix[i][j] = matrix[i - 1][j];
i--;
cnt++;
if (cnt % 10 == direction) {
return;
}
}
matrix[k - 1][k - 1] = tmp;
}
}
int main() {
int n, m;
cin >> n >> m;
vector<vector<int>> matrix(n, vector<int>(m));
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
cin >> matrix[i][j];
}
}
int num;
cin >> num;
while (num) {
int direction = num % 10;
rotate(matrix, direction);
num /= 10;
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
cout << matrix[i][j] << " ";
}
cout << endl;
}
return 0;
}
```
这里使用了一个变量 cnt 来记录旋转了多少个格子,每旋转一个格子就将其加 1。每次旋转时,判断 cnt 是否满足旋转方向即可。