传送门:UVA-253
依此将第二个正方体的六个面转至第一个的1上,随后旋转第二个正方体判断二者能否相等
AC代码:
#include<iostream>
#include<cstring>
using namespace std;
int main()
{
string pq,a,b;
int yu[]={0,6,5,4,3,2,1};//yu存储每个面对应的面,从第一个开始存
while(cin>>pq){
a=pq.substr(0,6);a.insert(a.begin(),'0');
b=pq.substr(6,12);b.insert(b.begin(),'0');//分离两个字符串
char tmpa[5];
int flag=0;
tmpa[0]=a[2];tmpa[1]=a[4];tmpa[2]=a[5];tmpa[3]=a[3];tmpa[4]=0;//1,6面固定,剩余面按顺时针存储
for(int i=1;i<=6;++i)
if(a[1]==b[i]&&a[6]==b[yu[i]]){//选出b中的两个面固定在1,6的位置
char tmpb[5];//相应的剩余面按顺时针存储
if(i==1) tmpb[0]=b[2],tmpb[1]=b[4],tmpb[2]=b[5],tmpb[3]=b[3];
else if(i==6) tmpb[0]=b[2],tmpb[1]=b[3],tmpb[2]=