c++输入两个整数n和m(小于10),输入n行m列矩阵,将这个矩阵逆时针旋转90度输出。
时间: 2024-03-09 20:47:50 浏览: 148
好的,这里是C++代码实现:
```c++
#include <iostream>
using namespace std;
int main() {
int n, m;
cin >> n >> m;
int a[n][m];
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
cin >> a[i][j];
}
}
for (int j = m - 1; j >= 0; j--) {
for (int i = 0; i < n; i++) {
cout << a[i][j] << " ";
}
cout << endl;
}
return 0;
}
```
该程序首先输入矩阵的行数和列数n和m,然后定义一个n行m列的二维数组a,并用两重循环读入矩阵元素。接下来,我们逆时针旋转矩阵90度,可以发现逆时针旋转后的矩阵的第j列就变成了旋转前矩阵的第n-j-1行(下标从0开始)。因此,我们可以再次使用两重循环输出旋转后的矩阵,其中第一重循环遍历矩阵的列,第二重循环遍历矩阵的行,最后每行输出完毕后换行即可。
希望对你有所帮助!
相关问题
题目描述 输入一个行和列为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++解
题目还是比较简单的,可以用一个函数来完成对矩阵的旋转操作。具体实现可以参考以下代码:
```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 是否满足旋转方向即可。
用C++编写一个程序 编程实现自动填充n×n矩阵元素数值,填充规则为:从第一行最后一列矩阵元素开始按逆时针方向螺旋式填充数值1,2,…,n×n,其中:n从键盘输入且3≤n≤20。最后向显示器输出该矩阵所有元素。
### 回答1:
以下是使用C++实现自动填充n×n矩阵的代码:
```cpp
#include <iostream>
using namespace std;
int main() {
int n;
cout << "请输入矩阵的大小n(3≤n≤20):";
cin >> n;
int matrix[20][20] = {0};
int x = 0, y = n - 1, num = 1;
// 从第一行最后一列元素开始按逆时针方向螺旋式填充数值
while (num <= n * n) {
// 向左填充
for (int i = y; i >= 0; i--) {
if (matrix[x][i] == 0) {
matrix[x][i] = num++;
}
}
// 向上填充
for (int i = x + 1; i < n; i++) {
if (matrix[i][y] == 0) {
matrix[i][y] = num++;
}
}
// 向右填充
for (int i = y - 1; i >= 0; i--) {
if (matrix[n - 1][i] == 0) {
matrix[n - 1][i] = num++;
}
}
// 向下填充
for (int i = n - 2; i >= x + 1; i--) {
if (matrix[i][0] == 0) {
matrix[i][0] = num++;
}
}
x++;
y--;
}
// 输出矩阵
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
cout << matrix[i][j] << "\t";
}
cout << endl;
}
return 0;
}
```
该程序首先从键盘输入矩阵大小n,然后创建一个n×n的矩阵并初始化为0。接下来,根据填充规则从第一行最后一列元素开始按逆时针方向螺旋式填充数值1至n×n。最后,将填充好的矩阵输出到显示器中。
### 回答2:
以下是用C语言编写的程序实现自动填充n×n矩阵元素数值的示例:
```c
#include <stdio.h>
#define MAX_SIZE 20
int main() {
int matrix[MAX_SIZE][MAX_SIZE];
int n, num = 1;
int row, col;
printf("请输入矩阵的大小n(3≤n≤20):");
scanf("%d", &n);
// 初始化矩阵
for (row = 0; row < n; row++) {
for (col = 0; col < n; col++) {
matrix[row][col] = 0;
}
}
row = 0;
col = n - 1;
// 螺旋式填充矩阵
while (num <= n * n) {
// 向上填充
while (row >= 0 && matrix[row][col] == 0) {
matrix[row--][col] = num++;
}
row++;
col--;
// 向左填充
while (col >= 0 && matrix[row][col] == 0) {
matrix[row][col--] = num++;
}
col++;
row++;
// 向下填充
while (row < n && matrix[row][col] == 0) {
matrix[row++][col] = num++;
}
row--;
col++;
// 向右填充
while (col < n && matrix[row][col] == 0) {
matrix[row][col++] = num++;
}
col--;
row--;
}
// 输出矩阵
printf("填充后的矩阵为:\n");
for (row = 0; row < n; row++) {
for (col = 0; col < n; col++) {
printf("%-3d ", matrix[row][col]);
}
printf("\n");
}
return 0;
}
```
使用该程序,您可以输入矩阵的大小n,例如输入4,即可得到填充后的4×4矩阵如下:
```
填充后的矩阵为:
1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7
```
希望以上解答能满足您的需求。
### 回答3:
实现这个程序可以分为以下几个步骤:
1. 从键盘输入一个正整数n,确保它满足3≤n≤20。
2. 创建一个n×n的二维数组matrix来存储矩阵。
3. 初始化计数器count为1,并设置四个边界变量top、bottom、left、right。
4. 利用循环填充矩阵元素,直到count达到n×n为止:
a. 从右到左填充最上边的元素,同时count加1,top加1。
b. 从上到下填充最右边的元素,同时count加1,right减1。
c. 从左到右填充最下边的元素,同时count加1,bottom减1。
d. 从下到上填充最左边的元素,同时count加1,left加1。
5. 完成填充后,依次输出matrix中的所有元素。
以下是该程序的示例代码:
```c
#include <stdio.h>
int main() {
int n;
printf("请输入矩阵的大小n(3≤n≤20):");
scanf("%d", &n);
// 创建n×n的二维数组
int matrix[20][20];
int count = 1;
int top = 0, bottom = n - 1, left = 0, right = n - 1;
while (count <= n * n) {
// 从右到左填充最上边的元素
for (int i = right; i >= left; i--) {
matrix[top][i] = count++;
}
top++;
// 从上到下填充最右边的元素
for (int i = top; i <= bottom; i++) {
matrix[i][right] = count++;
}
right--;
// 从左到右填充最下边的元素
for (int i = right; i >= left; i--) {
matrix[bottom][i] = count++;
}
bottom--;
// 从下到上填充最左边的元素
for (int i = bottom; i >= top; i--) {
matrix[i][left] = count++;
}
left++;
}
// 输出矩阵中的所有元素
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
printf("%2d ", matrix[i][j]);
}
printf("\n");
}
return 0;
}
```
运行程序后,从键盘输入矩阵的大小n(3≤n≤20),程序将自动按照题目要求填充矩阵,并输出矩阵中的所有元素。
阅读全文