标签:cspan idtransmarkspa uspan idtransmarkspa
背景:一次编译通过加一次ac就是这么爽!!!!!!
思路:枚举六个面朝上,每种情况旋转4次的所有情况,一共24种,全部枚举出来比较即可!这里比较巧妙的是把每一种情况都写作一个长度为6的字符串,并在第七位加一个‘\0
‘,这样就可以用strcmp来比较了。
#include<stdio.h>
#include<string.h>
int main(void){
char l[7],r[7],temp[13];
l1: while(~scanf("%s",temp)){
for(int i=0;i < 12;i++){
if(i <6) l[i]=temp[i];
else r[i-6]=temp[i];
}
l[6]=r[6]='\0';
temp[0]=r[0];temp[1]=r[1];temp[5]=r[5];temp[4]=r[4];temp[2]=r[2];temp[3]=r[3];temp[6]='\0';
for(int i=0;i < 4;i++){
if(strcmp(l,temp) == 0){
printf("TRUE\n");
goto l1;
}
char c=temp[1];
temp[1]=temp[2];temp[2]=temp[4];temp[4]=temp[3];temp[3]=c;
}
temp[0]=r[1];temp[1]=r[5];temp[5]=r[4];temp[4]=r[0];temp[2]=r[2];temp[3]=r[3];temp[6]='\0';
for(int i=0;i < 4;i++){
if(strcmp(l,temp) == 0){
printf("TRUE\n");
goto l1;
}
char c=temp[1];
temp[1]=temp[2];temp[2]=temp[4];temp[4]=temp[3];temp[3]=c;
}
temp[0]=r[5];temp[1]=r[4];temp[5]=r[0];temp[4]=r[1];temp[2]=r[2];temp[3]=r[3];temp[6]='\0';
for(int i=0;i < 4;i++){
if(strcmp(l,temp) == 0){
printf("TRUE\n");
goto l1;
}
char c=temp[1];
temp[1]=temp[2];temp[2]=temp[4];temp[4]=temp[3];temp[3]=c;
}
temp[0]=r[4];temp[1]=r[0];temp[5]=r[1];temp[4]=r[5];temp[2]=r[2];temp[3]=r[3];temp[6]='\0';
for(int i=0;i < 4;i++){
if(strcmp(l,temp) == 0){
printf("TRUE\n");
goto l1;
}
char c=temp[1];
temp[1]=temp[2];temp[2]=temp[4];temp[4]=temp[3];temp[3]=c;
}
//two
temp[0]=r[2];temp[1]=r[1];temp[2]=r[5];temp[3]=r[0];temp[4]=r[4];temp[5]=r[3];temp[6]='\0';
for(int i=0;i < 4;i++){
if(strcmp(l,temp) == 0){
printf("TRUE\n");
goto l1;
}
char c=temp[1];
temp[1]=temp[2];temp[2]=temp[4];temp[4]=temp[3];temp[3]=c;
}
temp[0]=r[3];temp[1]=r[1];temp[2]=r[0];temp[3]=r[5];temp[4]=r[4];temp[5]=r[2];temp[6]='\0';
for(int i=0;i < 4;i++){
if(strcmp(l,temp) == 0){
printf("TRUE\n");
goto l1;
}
char c=temp[1];
temp[1]=temp[2];temp[2]=temp[4];temp[4]=temp[3];temp[3]=c;
}
printf("FALSE\n");
}
return 0;
}
标签:cspan idtransmarkspa uspan idtransmarkspa
原文地址:http://blog.csdn.net/jibancanyang/article/details/43372923