POJ 1096 Space Station Shielding

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <queue>
 5 #define sc(x) scanf("%d",&x)
 6 #define CL(x, y) memset(x,y,sizeof(x))
 7 using namespace std;
 8 const int MAX = 66;
 9 int A, B, C, D, i, num;
10 int used[MAX][MAX][MAX];
11 int tower[MAX][MAX][MAX];
12 int Move[6][3]= {{1,0,0},{0,1,0},{0,0,1},{-1,0,0},{0,-1,0},{0,0,-1}};
13 void BFS(int a, int b, int c);
14 bool check(int x, int y, int z);
15 struct node
16 {
17     int x, y, z;
18     int time;
19 };
20 queue <node> Q;
21 void BFS();
22 int main()
23 {
24     while(scanf("%d%d%d%d",&A,&B,&C,&D)!=EOF)
25     {
26         if(!A && !B && !C && !D) break;
27         CL(tower, 0);
28         CL(used, 0);
29         int temp;
30         for(i = 0; i < D; i++)
31         {
32             sc(temp);
33             tower[temp%(A*B)%A+1][temp%(A*B)/A+1][temp/(A*B)+1] = 1;//=1是外面包了一层
34         }
35         BFS(0, 0, 0);
36         printf("The number of faces needing shielding is %d.\n", num);
37 
38     }
39     return 0;
40 }
41 void BFS(int a, int b, int c)
42 {
43     int xx, yy, zz;
44     num = 0;
45     while(!Q.empty())
46         Q.pop();
47     node fir, cur, next;
48     fir.x = a;
49     fir.y = b;
50     fir.z = c;
51     fir.time = 0;
52     used[a][b][c] = 1;
53     Q.push(fir);
54     while(!Q.empty())
55     {
56         cur = Q.front();
57         Q.pop();
58         for(i = 0; i < 6; i++)
59         {
60             xx = cur.x+Move[i][0];
61             yy = cur.y+Move[i][1];
62             zz = cur.z+Move[i][2];
63             if(check(xx, yy, zz))//在范围内 && !used[xx][yy][zz] && )//哥哥,0代表路,请看清题目!tower[xx][yy][zz]
64             {
65                 if(!tower[xx][yy][zz])//有路
66                 {
67                     if(!used[xx][yy][zz])//没走过
68                     {
69                         next.x = xx;
70                         next.y = yy;
71                         next.z = zz;
72                         next.time = cur.time+1;
73                         used[xx][yy][zz] = 1;
74                         Q.push(next);
75                     }
76                 }
77                 else
78                     num++;//反之则加1, 想反了
79             }
80         }
81     }
82     return ;
83 }
84 bool check(int x, int y, int z)
85 {
86     if(x>=0 && x<=A+1 && y>=0 && y<=B+1 && z>=0 && z<=C+1)//应该是A+1,肯定是加2
87         return true;
88     return false;
89 }
View Code

错在立方体的坐标,但是解题思路也很关键

  1 #include <iostream>
  2 #include <cstdio>
  3 #include <cstring>
  4 #include <queue>
  5 #define sc(x) scanf("%d",&x)
  6 #define CL(x, y) memset(x,y,sizeof(x))
  7 using namespace std;
  8 const int MAX = 66;
  9 int A, B, C, D, num;
 10 int used[MAX][MAX][MAX];
 11 int tower[MAX][MAX][MAX];
 12 int Move[6][3]= {{1,0,0},{0,1,0},{0,0,1},{-1,0,0},{0,-1,0},{0,0,-1}};
 13 bool check(int x, int y, int z);
 14 struct node
 15 {
 16     int x, y, z;
 17 //    int time;
 18 };
 19 void BFS();
 20 queue <node> Q;
 21 node madeQueue(int xx,int yy,int zz)
 22 {
 23     node rear;
 24     rear.x = xx;
 25     rear.y = yy;
 26     rear.z = zz;
 27     return rear;
 28 }
 29 int main()
 30 {
 31     while(scanf("%d%d%d%d",&A,&B,&C,&D)!=EOF)
 32     {
 33         if(!A && !B && !C && !D) break;
 34         CL(tower, 0);
 35         CL(used, 0);
 36         int temp;
 37         for(int j = 0; j < D; j++)
 38         {
 39             sc(temp);
 40             tower[temp%(B*A)%A+1][temp%(B*A)/A+1][temp/(A*B)+1] = 1;//=1是外面包了一层
 41         }
 42         BFS();
 43         cout<<"The number of faces needing shielding is "<< num <<".\n";
 44     }
 45     return 0;
 46 }
 47 void BFS()
 48 {
 49 //    int xx, yy, zz;
 50     num = 0;
 51 //    node fir, cur, next;
 52 //    fir.x = 0;
 53 //    fir.y = 0;
 54 //    fir.z = 0;
 55 //    fir.time = 0;
 56 //    used[0][0][0] = 1;
 57 //    Q.push(fir);
 58     Q.push(madeQueue(0,0,0));
 59     while(!Q.empty())
 60     {
 61         node cur = Q.front();
 62         Q.pop();
 63 //        for(i = 0; i < 6; i++)
 64 //        {
 65 //            xx = cur.x+Move[i][0];
 66 //            yy = cur.y+Move[i][1];
 67 //            zz = cur.z+Move[i][2];
 68 //            if(check(xx, yy, zz))//在范围内 && !used[xx][yy][zz] && )//哥哥,0代表路,请看清题目!tower[xx][yy][zz]
 69 //            {
 70 //                if(!tower[xx][yy][zz])//有路
 71 //                {
 72 //                    if(!used[xx][yy][zz])//没走过
 73 //                    {
 74 //                        next.x = xx;
 75 //                        next.y = yy;
 76 //                        next.z = zz;
 77 ////                        next.time = cur.time+1;
 78 ////                num++;
 79 //                        used[xx][yy][zz] = 1;
 80 //                        Q.push(next);
 81 //                    }
 82 //                }
 83 //                else
 84 //                    num++;//反之则加1, 想反了
 85 //            }
 86 //        }
 87         if(used[cur.x][cur.y][cur.z])continue;
 88         used[cur.x][cur.y][cur.z] = 1;
 89         if(cur.x>=1)
 90         {
 91             if(!tower[cur.x-1][cur.y][cur.z])
 92             {
 93                 if(!used[cur.x-1][cur.y][cur.z])
 94                 {
 95 //                    next.x = cur.x-1;
 96 //                    next.y = cur.y;
 97 //                    next.z = cur.z;
 98 //                    Q.push(next);
 99                     Q.push(madeQueue(cur.x-1,cur.y,cur.z));
100                 }
101             }
102             else num++;
103         }//左走一格
104         if(cur.x<=A)
105         {
106             if(!tower[cur.x+1][cur.y][cur.z])
107             {
108                 if(!used[cur.x+1][cur.y][cur.z])
109                 {
110 //                    next.x = cur.x+1;
111 //                    next.y = cur.y;
112 //                    next.z = cur.z;
113 //                    Q.push(next);
114                     Q.push(madeQueue(cur.x+1,cur.y,cur.z));
115                 }
116             }
117             else num++;
118         }//右走一格
119         if(cur.y>=1)
120         {
121             if(!tower[cur.x][cur.y-1][cur.z])
122             {
123                 if(!used[cur.x][cur.y-1][cur.z])
124                 {
125 //                    next.x = cur.x;
126 //                    next.y = cur.y-1;
127 //                    next.z = cur.z;
128 //                    Q.push(next);
129                     Q.push(madeQueue(cur.x,cur.y-1,cur.z));
130                 }
131             }
132             else num++;
133         }//后走一格
134         if(cur.y<=B)
135         {
136             if(!tower[cur.x][cur.y+1][cur.z])
137             {
138                 if(!used[cur.x][cur.y+1][cur.z])
139                 {
140 //                    next.x = cur.x;
141 //                    next.y = cur.y+1;
142 //                    next.z = cur.z;
143 //                    Q.push(next);
144                     Q.push(madeQueue(cur.x,cur.y+1,cur.z));
145                 }
146             }
147             else num++;
148         }//前走一格
149         if(cur.z>=1)
150         {
151             if(!tower[cur.x][cur.y][cur.z-1])
152             {
153                 if(!used[cur.x][cur.y][cur.z-1])
154                 {
155 //                    next.x = cur.x;
156 //                    next.y = cur.y;
157 //                    next.z = cur.z-1;
158 //                    Q.push(next);
159                     Q.push(madeQueue(cur.x,cur.y,cur.z-1));
160                 }
161             }
162             else num++;
163         }//下走一格
164         if(cur.z<=C)
165         {
166             if(!tower[cur.x][cur.y][cur.z+1])
167             {
168                 if(!used[cur.x][cur.y][cur.z+1])
169                 {
170 //                    next.x = cur.x;
171 //                    next.y = cur.y;
172 //                    next.z = cur.z+1;
173 //                    Q.push(next);
174                     Q.push(madeQueue(cur.x,cur.y,cur.z+1));
175                 }
176             }
177             else num++;
178         }//上走一格
179     }
180 //    printf("The number of faces needing shielding is %d.\n", num);
181     while(!Q.empty())
182         Q.pop();
183 }
184 bool check(int x, int y, int z)
185 {
186     if(x>=0 && x<=A+1 && y>=0 && y<=B+1 && z>=0 && z<=C+1)//应该是A+1,肯定是加2
187         return true;
188     return false;
189 }
View Code

 

posted @ 2015-03-12 12:35  PastLIFE  阅读(173)  评论(0编辑  收藏  举报