当前位置: 代码迷 >> 综合 >> 矩阵旋转模板
  详细解决方案

矩阵旋转模板

热度:95   发布时间:2023-09-20 19:10:59.0

矩阵旋转在做题的时候会遇到
我百度一下想找到已经总结过的模板
没找到
所以我干脆就自己写了

 

#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;
}

 

  相关解决方案