矩阵旋转在做题的时候会遇到
我百度一下想找到已经总结过的模板
没找到
所以我干脆就自己写了
#include<cstdio>
#define _for(i, a, b) for(int i = (a); i <= (b); i++)
using namespace std;const int MAXN = 112;
int a[MAXN][MAXN], n, m;int main()
{scanf("%d%d", &n, &m);_for(i, 1, n)_for(j, 1, m)scanf("%d", &a[i][j]);puts("");_for(i, 1, n) //左右翻转_for(j, 1, m){printf("%-3d", a[i][m-j+1]);if(j == m) puts("");}puts("");_for(i, 1, n) //上下翻转_for(j, 1, m){printf("%-3d", a[n-i+1][j]);if(j == m) puts("");}puts("");_for(i, 1, m) //顺时针90度翻转_for(j, 1, n) //注意i对应m,j对应n {printf("%-3d", a[n-j+1][i]);if(j == n) puts("");}puts("");_for(i, 1, m) //逆时针90度翻转_for(j, 1, n){printf("%-3d", a[j][m-i+1]);if(j == n) puts("");}puts("");_for(i, 1, n) //180度翻转 _for(j, 1, m){printf("%-3d", a[n-i+1][m-j+1]);if(j == m) puts("");}puts("");return 0;
}