Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 10778 Accepted Submission(s): 2873
Special Judge
1 2 3 4
5 6 7 8
9 10 11 12
13 14 15 x
1 2 3 4 1 2 3 4 1 2 3 4 1 2 3 4
5 6 7 8 5 6 7 8 5 6 7 8 5 6 7 8
9 x 10 12 9 10 x 12 9 10 11 12 9 10 11 12
13 14 11 15 13 14 11 15 13 14 x 15 13 14 15 x
r-> d-> r->
1 #include<iostream> 2 #include<stdio.h> 3 #include<cstring> 4 #include<cstdlib> 5 #include<string> 6 #include<queue> 7 using namespace std; 8 9 struct node 10 { 11 bool flag; 12 char str; 13 int father; 14 }hash[363001]; 15 struct st 16 { 17 char t[10]; 18 }; 19 queue<st>Q; 20 int ans[10]={1}; 21 22 int ktzk(char *c) 23 { 24 int i,j,k,sum=0; 25 for(i=0;i<=8;i++) 26 { 27 k=0; 28 for(j=i+1;j<=8;j++) 29 if(c[i]>c[j]) 30 k++; 31 sum=sum+k*ans[8-i]; 32 } 33 return sum; 34 } 35 void bfs() 36 { 37 int i,k,num,val; 38 struct st cur,t; 39 k=ktzk("123456780"); 40 hash[k].flag=true; 41 hash[k].str='\0'; 42 hash[k].father=k; 43 44 strcpy(t.t,"123456780"); 45 Q.push(t); 46 47 while(!Q.empty()) 48 { 49 cur=Q.front(); 50 Q.pop(); 51 val=ktzk(cur.t); 52 for(i=0;i<=8;i++) 53 { 54 if(cur.t[i]=='0') 55 { 56 k=i; 57 break; 58 } 59 } 60 if(k!=2 && k!=5 && k!=8)//rigth 61 { 62 t=cur; 63 swap(t.t[k],t.t[k+1]); 64 num=ktzk(t.t); 65 if(hash[num].flag==false) 66 { 67 hash[num].flag=true; 68 hash[num].str='r'; 69 hash[num].father=val; 70 Q.push(t); 71 } 72 } 73 if(k!=0 && k!=3 && k!=6)//left 74 { 75 t=cur; 76 swap(t.t[k],t.t[k-1]); 77 num=ktzk(t.t); 78 if(hash[num].flag==false) 79 { 80 hash[num].flag=true; 81 hash[num].str='l'; 82 hash[num].father=val; 83 Q.push(t); 84 } 85 } 86 if(k>=3)//u 87 { 88 t=cur; 89 swap(t.t[k],t.t[k-3]); 90 num=ktzk(t.t); 91 if(hash[num].flag==false) 92 { 93 hash[num].flag=true; 94 hash[num].str='u'; 95 hash[num].father=val; 96 Q.push(t); 97 } 98 } 99 if(k<=5)//D 100 { 101 t=cur; 102 swap(t.t[k],t.t[k+3]); 103 num=ktzk(t.t); 104 if(hash[num].flag==false) 105 { 106 hash[num].flag=true; 107 hash[num].str='d'; 108 hash[num].father=val; 109 Q.push(t); 110 } 111 } 112 } 113 } 114 void prepare() 115 { 116 int i; 117 for(i=0;i<=363000;i++) 118 { 119 hash[i].flag=false; 120 } 121 for(i=1;i<=9;i++) ans[i]=ans[i-1]*i; 122 bfs(); 123 } 124 int main() 125 { 126 prepare(); 127 char a[50],b[10],c[100]; 128 bool tom[10]; 129 int i,j,k,cur; 130 while(gets(a)) 131 { 132 k=strlen(a); 133 b[9]='\0'; 134 for(i=0,j=0;i<k;i++) 135 { 136 if(a[i]=='x' || (a[i]>='1'&&a[i]<='8')) 137 { 138 if(a[i]=='x') 139 b[j]='0'; 140 else b[j]=a[i]; 141 j++; 142 } 143 } 144 memset(tom,false,sizeof(tom)); 145 for(i=0;i<=8;i++) 146 { 147 tom[b[i]-'0']=true; 148 } 149 for(i=0;i<=8;i++) 150 { 151 if(tom[i]==false) 152 break; 153 } 154 if(i<=8){printf("unsolvable\n");continue;} 155 cur=ktzk(b); 156 if(hash[cur].flag==false) 157 { 158 printf("unsolvable\n"); 159 continue; 160 } 161 k=0; 162 while(hash[cur].father!=cur) 163 { 164 c[k]=hash[cur].str; 165 k++; 166 cur=hash[cur].father; 167 } 168 for(i=0;i<=k-1;i++) 169 { 170 if(c[i]=='u')printf("d"); 171 if(c[i]=='d')printf("u"); 172 if(c[i]=='l')printf("r"); 173 if(c[i]=='r')printf("l"); 174 } 175 printf("\n"); 176 } 177 return 0; 178 }