问题描述
旋转是图像处理的基本操作,在这个问题中,你需要将一个图像逆时针旋转90度。
计算机中的图像表示可以用一个矩阵来表示,为了旋转一个图像,只需要将对应的矩阵旋转即可。
输入格式
输入的第一行包含两个整数n, m,分别表示图像矩阵的行数和列数。
接下来n行每行包含m个整数,表示输入的图像。
输出格式
输出m行,每行包含n个整数,表示原始矩阵逆时针旋转90度后的矩阵。
样例输入
2 3
1 5 3
3 2 4
样例输出
3 4
5 2
1 3
评测用例规模与约定
1 ≤ n, m ≤ 1,000,矩阵中的数都是不超过1000的非负整数。
解题思路:本质上其实可以对先正常建立的一个矩阵(二维数组)进行输出上的改变而不用真正进行数组内部数据的更改。即按题目要求就是先输出原来矩阵的最后一列作为新矩阵的第一行,然后依次往前。如样例就是先输出了第三列第一行的元素,再输出第三列第二行的元素,然后依据原来的行数进行换行
解题代码:
#include <stdio.h>
int main() {
int n = 0, m = 0;
scanf("%d%d", &n, &m);
int arr[n][m];
int i = 0, j = 0;
for (i = 0; i < n; i++)
for (j = 0; j < m; j++)
scanf("%d", &arr[i][j]);
for (j = m - 1; j >= 0; j--)
{
for (i = 0; i < n; i++)
printf("%d ", arr[i][j]);
printf("\n");
}
return 0;
}
看完觉得有觉得帮助的话不妨点赞收藏鼓励一下,有疑问或看不懂的地方或有可优化的部分还恳请朋友们留个评论,多多指点,谢谢朋友们!