Sicily 1150. 简单魔板

BFS。军训晚上下雨无聊写的水题。

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <algorithm>
 4 #include <cstring>
 5 #include <queue>
 6 #include <vector>
 7 #define rep(i,l,r) for(int i = l; i <= r; i++)
 8 #define clr(x,y) memset(x,y,sizeof(x))
 9 #define travel(x) for(Edge *p = last[x]; p; p = p -> pre)
10 using namespace std;
11 inline int read(){
12     int ans = 0, f = 1; char c = getchar();
13     for(; !isdigit(c); c = getchar()) if (c == '-') f = -1;
14     for(; isdigit(c); c = getchar()) ans = ans * 10 + c - '0';
15     return ans * f;
16 }
17 int N, n, target;
18 struct Node{
19     int num; vector <char> path;
20 };
21 queue <Node> q;
22 inline int A(int x){
23     int h = x / 10000; int l = x % 10000;
24     return l * 10000 + h;
25 }
26 inline int B(int x){
27     int h = x / 10000; int l = x % 10000;
28     int hh = h / 10; int hl = h % 10;
29     int lh = l / 10; int ll = l % 10;
30     return hl * 10000000 + hh * 10000 + ll * 1000 + lh;
31 }
32 inline int C(int x){
33     int t[9]; rep(i,1,8){
34         t[8 - i + 1] = x % 10;
35         x = x / 10;
36     }
37     return t[1] * 1e7 + t[6] * 1e6 + t[2] * 1e5 + t[4] * 1e4 + t[5] * 1e3 + t[7] * 1e2 + t[3] * 10 + t[8];
38 }
39 Node bfs(){
40     while (!q.empty()) q.pop();
41     Node s; s.num = 12348765;
42     q.push(s);
43     while (!q.empty()){
44         Node now = q.front(); q.pop();
45         if (now.path.size() > N) return now;
46         else{
47             Node fun1 = now;
48             fun1.num = A(fun1.num);
49             fun1.path.push_back('A');
50             if (fun1.num == target) return fun1;
51             else q.push(fun1);
52             Node fun2 = now;
53             fun2.num = B(fun2.num);
54             fun2.path.push_back('B');
55             if (fun2.num == target) return fun2;
56             else q.push(fun2);
57             Node fun3 = now;
58             fun3.num = C(fun3.num);
59             fun3.path.push_back('C');
60             if (fun3.num == target) return fun3;
61             else q.push(fun3);
62         }
63     }
64 }
65 void work(){
66     target = 0;
67     rep(i,1,8){
68         int x = read(); target = target * 10 + x; 
69     }
70     Node out = bfs(); int cnt = out.path.size();
71     if (cnt > N) printf("-1\n");
72     else{
73         printf("%d ",cnt);
74         rep(i,0,cnt - 1) printf("%c",out.path[i]);
75         printf("\n");
76     }
77 }
78 int main(){
79     N = read();
80     while (N != -1){
81         work(); N = read();
82     }
83     return 0;
84 }
View Code

 

posted on 2017-09-14 23:17  ACMICPC  阅读(152)  评论(0编辑  收藏  举报

导航