//ans[1]-ans[6]分别记录 东 西 北 南 上 下 的值,我们可以确定最后一定要转到://ans[1]=1,ans[3]=2,即 the east face is 1, the north face is 2, //为了判断是 left或是 right ,我们要先把 东 面转到 1 ,再把 北 面转到 2,//最后如果 上 面是3,则是right; 如果 下 面是3,则是left#include<iostream>#include<stdio.h>using namespace std;int main(){ char ch[10];int ans[10],tmp;while(cin>>ch+1) { for(int i=1;i<=6;++i) ans[i]=ch[i]-'0';if(ans[5]==1||ans[6]==1) //如果 1 是在 上 或 下 面,则需要先把 1 转到 水平面(东 西 北 南) { tmp=ans[5]; ans[5]=ans[4];ans[4]=ans[6];ans[6]=ans[3]; ans[3]=tmp; }while(ans[1]!=1) //在水平面进行旋转,因为每转 4 步就能回到原来状态,所以肯定可以在 3 步内把 东 面转到 1 { tmp=ans[2]; ans[2]=ans[4];ans[4]=ans[1];ans[1]=ans[3]; ans[3]=tmp;//水平面的旋转按照:北->东->南->西->北,即ans[3]->ans[1]->ans[4]->ans[2]->ans[3] }while(ans[3]!=2) //在垂直面进行旋转 { tmp=ans[5]; ans[5]=ans[4];ans[4]=ans[6];ans[6]=ans[3]; ans[3]=tmp;//垂直面的旋转按照:北->下->南->上->北,即ans[3]->ans[6]->ans[4]->ans[5]->ans[3] }if(ans[5]==3) //ans[5]==3表示 上 面是3 printf("right\n");else printf("left\n"); }return 0;}