2416 参考答案
1
2
3
4
5
6
7
8
9
10
11
12 #include
13 #include
14 using namespace std;
15 const int N=10000;
16 bool used[N];
17 queue<int> a;
18 queue<int> b;
19 int tran[11]={9,1,2,3,4,5,6,7,8,9,1};
20 int bit[4];
21 void addtob(int u)
22 {
23
24 int next;
25 int tmp=u;
26 for(int i=3;i>=0;i--)
27 {
28 bit[i]=tmp%10;
29 tmp=tmp/10;
30 }
31 for(int i=0;i<=3;i++)
32 {
33 tmp=bit[i];
34 bit[i]=tran[bit[i]+1];
35 next=1000*bit[0]+100*bit[1]+10*bit[2]+bit[3];
36 if(!used[next]) { b.push(next);used[next]=true;}
37 bit[i]=tmp;
38 bit[i]=tran[bit[i]-1];
39 next=1000*bit[0]+100*bit[1]+10*bit[2]+bit[3];
40 if(!used[next]) { b.push(next);used[next]=true;}
41 bit[i]=tmp;
42 }
43 next=1000*bit[1]+100*bit[0]+10*bit[2]+bit[3];
44 if(!used[next]) { b.push(next);used[next]=true;}
45
46 next=1000*bit[0]+100*bit[2]+10*bit[1]+bit[3];
47 if(!used[next]) { b.push(next);used[next]=true;}
48
49 next=1000*bit[0]+100*bit[1]+10*bit[3]+bit[2];
50 if(!used[next]) { b.push(next);used[next]=true;}
51 }
52 int BFS(int n,int m)
53 {
54 while(!a.empty())
55 a.pop();
56 while(!b.empty())
57 b.pop();
58 memset(used,0,sizeof(used));
59 a.push(n);
60 used[n]=true;
61 int ans=0;
62 int u;
63 while(1)
64 {
65 while(!a.empty())
66 {
67 u=a.front();
68 if(u==m) return ans;
69 a.pop();
70 addtob(u);
71 }
72 while(!b.empty())
73 {
74 u=b.front();
75 b.pop();
76 a.push(u);
77 }
78 ans++;
79 }
80 }
81 int main()
82 {
83 int test;
84 cin>>test;
85 int n,m;
86 while(test-->0)
87 {
88 cin>>n>>m;
89 cout<<BFS(n,m)<<endl;
90 }
91 }
1
2
3
4
5
6
7
8
9
10
11
12
13 #include
14 #include
15 using namespace std;
16 const int N=10000;
17 bool used[N];
18 queue<int> a;
19 queue<int> b;
20 void addtob(int u)
21 {
22 int t,x,y,z;
23 int next;
24 int tmp=u;
25 z=tmp%10;tmp=tmp/10;
26 y=tmp%10;tmp=tmp/10;
27 x=tmp%10;
28 t=tmp/10;
29
30
31 if(t==9) next=u-8000;
32 else next=u+1000;
33 if(!used[next]) { b.push(next);used[next]=true;}
34
35 if(x==9) next=u-800;
36 else next=u+100;
37 if(!used[next]) { b.push(next);used[next]=true;}
38
39 if(y==9) next=u-80;
40 else next=u+10;
41 if(!used[next]) { b.push(next);used[next]=true;}
42
43 if(z==9) next=u-8;
44 else next=u+1;
45 if(!used[next]) { b.push(next);used[next]=true;}
46
47 if(t==1) next=u+8000;
48 else next=u-1000;
49 if(!used[next]) { b.push(next);used[next]=true;}
50
51 if(x==1) next=u+800;
52 else next=u-100;
53 if(!used[next]) { b.push(next);used[next]=true;}
54
55 if(y==1) next=u+80;
56 else next=u-10;
57 if(!used[next]) { b.push(next);used[next]=true;}
58
59 if(z==1) next=u+8;
60 else next=u-1;
61 if(!used[next]) { b.push(next);used[next]=true;}
62
63 next=x*1000+t*100+10*y+z;
64 if(!used[next]) { b.push(next);used[next]=true;}
65
66 next=1000*t+y*100+x*10+z;
67 if(!used[next]) { b.push(next);used[next]=true;}
68
69 next=1000*t+x*100+z*10+y;
70 if(!used[next]) { b.push(next);used[next]=true;}
71
72 }
73 int BFS(int n,int m)
74 {
75 while(!a.empty())
76 a.pop();
77 while(!b.empty())
78 b.pop();
79 memset(used,0,sizeof(used));
80 a.push(n);
81 used[n]=true;
82 int ans=0;
83 int u;
84 while(1)
85 {
86 while(!a.empty())
87 {
88 u=a.front();
89 if(u==m) return ans;
90 a.pop();
91 addtob(u);
92 }
93 while(!b.empty())
94 {
95 u=b.front();
96 b.pop();
97 a.push(u);
98 }
99 ans++;
100 }
101 }
102 int main()
103 {
104 int test;
105 cin>>test;
106 int n,m;
107 while(test-->0)
108 {
109 cin>>n>>m;
110 cout<<BFS(n,m)<<endl;
111 }
112 }
2416 参考答案 (2008-11-12 14:10:52由218编辑)