说实话写这个题,上面的三角形把我误导了,我一直没看懂这个三角形啥意思,所以我直接看样例就明白了;
分析:这道题意思是一个33的矩阵可以分为4个不同的22的矩阵也就是:
左边的就是右边的22合并的,注意中间是重叠的看成一个;
这样这道题容易了,后面的1C表示第一个22矩阵顺时针转90度,4R表示第四个22逆时针转90度;
理解到这个就OK了(提醒一下:字符数组要开大一点哈(别33)因为输入字符串系统会自动加上一个\0结束所以如果是3那么内存就会溢出(后果意想不到,嘻嘻));
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main(){
char a[5][5],ch[5];
int T;
scanf("%d",&T);
while(T--){
int m;
scanf("%d",&m);
for(int i=0;i<3;i++){
scanf("%s",a[i]);
}
char t;
while(m--){
scanf("%s",ch);
switch(ch[0]){
case '1': //第一个2*2
if(ch[1]=='R'){
t=a[0][0];a[0][0]=a[0][1];a[0][1]=a[1][1];a[1][1]=a[1][0];a[1][0]=t;
}else{
t=a[0][0];a[0][0]=a[1][0];a[1][0]=a[1][1];a[1][1]=a[0][1];a[0][1]=t;
}; break;
case '2'://第二个2*2
if(ch[1]=='R'){
t=a[0][1];a[0][1]=a[0][2];a[0][2]=a[1][2];a[1][2]=a[1][1];a[1][1]=t;
}else{
t=a[0][1];a[0][1]=a[1][1];a[1][1]=a[1][2];a[1][2]=a[0][2];a[0][2]=t;
} ;break;
case '3': //第三个2*2
if(ch[1]=='R'){
t=a[1][0];a[1][0]=a[1][1];a[1][1]=a[2][1];a[2][1]=a[2][0];a[2][0]=t;
}else{
t=a[1][0];a[1][0]=a[2][0];a[2][0]=a[2][1];a[2][1]=a[1][1];a[1][1]=t;
} ;break;
case '4': //第四个2*2
if(ch[1]=='R'){
t=a[1][1];a[1][1]=a[1][2];a[1][2]=a[2][2];a[2][2]=a[2][1];a[2][1]=t;
}else{
t=a[1][1];a[1][1]=a[2][1];a[2][1]=a[2][2];a[2][2]=a[1][2];a[1][2]=t;
} ;break;
default:break;
}
}
for(int i=0;i<3;i++){
printf("%s\n",a[i]);
}
}
return 0;
}