描述
输入一个n行m列的黑白图像,将它顺时针旋转90度后输出。
输入
第一行包含两个整数n和m,表示图像包含像素点的行数和列数。1 <= n <= 100,1 <= m <= 100。
接下来n行,每行m个整数,表示图像的每个像素点灰度。相邻两个整数之间用单个空格隔开,每个元素均在0~255之间。
输出
m行,每行n个整数,为顺时针旋转90度后的图像。相邻两个整数之间用单个空格隔开。
样例输入
3 3
1 2 3
4 5 6
7 8 9
样例输出
7 4 1
8 5 2
9 6 3
分析:
将二维数组进行顺时针90°旋转,可以从中发现,数组的行和列发生了转换,也就是说,数组的第一列的元素转换为第一行的元素倒序输出,第二列的元素转换为第二行的元素倒序输出,以此类推。而考虑到行数列数可能会存在不同,从而导致转换的元素不能到达正确的位置,在输出时需要注意行数和列数的转变。
具体代码:
#include <iostream>
using namespace std;
int main()
{
int n,m;
cin>>n>>m;
int a[100][100]; //创建二维数组,将所需要的的n行m列图像存入
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
cin>>a[i][j]; //输入数组
}
}
for(int i=0;i<m;i++) //图像旋转时注意行数和列数的变化
{
for(int j=n-1;j>=0;j--)
{
cout<<a[j][i]<<" ";
}
cout<<endl;
}
return 0;
}
运行结果: