C:图像旋转
- 总时间限制:
- 1000ms
- 内存限制:
- 65536kB
- 描述
-
输入一个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
#include <iostream> #include <algorithm> #include <stdio.h> #include <string> #include <ctype.h> using namespace std; int ma[101][101]; int mb[101][101]; int main() { int m, n; scanf("%d%d", &m, &n); for(int i = 0; i < m; i++) { for(int j = 0; j < n; j++) { scanf("%d", &ma[j][i]); mb[j][m-1-i] = ma[j][i]; } } for(int i = 0; i < n; i++) { for(int j = 0; j < m; j++) { if(j != m-1) printf("%d ", mb[i][j]); else printf("%d", mb[i][j]); } printf(" "); } return 0; }