hdu 4531 bfs(略难)

题目链接:点我

第一次不太清楚怎么判重,现在懂了,等下次再做

  1 /*
  2 *HDU 4531
  3 *BFS
  4 *注意判重
  5 */
  6
  7
  8 #include <stdio.h>
  9 #include <string.h>
 10 #include <algorithm>
 11 #include <map>
 12 #include <set>
 13 #include <string>
 14 #include <queue>
 15 #include <iostream>
 16 using namespace std;
 17
 18 char str[3][3][6];
 19 char g[3][3][6];
 20
 21 map<int,int>mp;
 22 queue<int>q;
 23 bool move[6];//是否可以移动,0~5对应1~3行,1~3列
 24
 25 //并查集判断连通
 26 int F[50];
 27 int find(int x)
 28 {
 29     if(F[x]==-1)return x;
 30     return F[x]=find(F[x]);
 31 }
 32 void bing(int x,int y)
 33 {
 34     int t1=find(x);
 35     int t2=find(y);
 36     if(t1!=t2)F[t1]=t2;
 37 }
 38 //并查集判断是不是连通
 39 bool judge(int state)//判断状态state是不是连通
 40 {
 41     char temp[10];
 42     int t[10];
 43     sprintf(temp,"%09d",state);
 44     for(int i=0;i<9;i++)t[i]=temp[i]-‘0‘;
 45     for(int i=0;i<3;i++)
 46       for(int j=0;j<3;j++)
 47       {
 48           int p=t[3*i+j];
 49           int x=p/3;
 50           int y=p%3;
 51           strcpy(g[i][j],str[x][y]);
 52       }
 53     memset(F,-1,sizeof(F));
 54     for(int i=0;i<3;i++)
 55       for(int j=0;j<3;j++)
 56       {
 57           if(g[i][j][0]==g[i][j][2])bing(12*i+4*j,12*i+4*j+2);
 58           if(g[i][j][0]==g[i][j][3])bing(12*i+4*j,12*i+4*j+3);
 59           if(g[i][j][1]==g[i][j][2])bing(12*i+4*j+1,12*i+4*j+2);
 60           if(g[i][j][1]==g[i][j][3])bing(12*i+4*j+1,12*i+4*j+3);
 61       }
 62     for(int i=0;i<3;i++)
 63     {
 64         if(g[i][0][3]==g[i][1][2])bing(12*i+3,12*i+4+2);
 65         if(g[i][1][3]==g[i][2][2])bing(12*i+4+3,12*i+8+2);
 66     }
 67     for(int j=0;j<3;j++)
 68     {
 69         if(g[0][j][1]==g[1][j][0])bing(4*j+1,12+4*j+0);
 70         if(g[1][j][1]==g[2][j][0])bing(12+4*j+1,24+4*j+0);
 71     }
 72     int R=-1,G=-1,B=-1,O=-1;
 73     for(int i=0;i<3;i++)
 74       for(int j=0;j<3;j++)
 75         for(int k=0;k<4;k++)
 76         {
 77             int t1=find(12*i+4*j+k);
 78             if(g[i][j][k]==‘R‘)
 79             {
 80                 if(R==-1)R=t1;
 81                 else if(t1!=R)return false;
 82             }
 83             else if(g[i][j][k]==‘G‘)
 84             {
 85                 if(G==-1)G=t1;
 86                 else if(t1!=G)return false;
 87             }
 88             else if(g[i][j][k]==‘B‘)
 89             {
 90                 if(B==-1)B=t1;
 91                 else if(t1!=B)return false;
 92             }
 93             else
 94             {
 95                 if(O==-1)O=t1;
 96                 else if(t1!=O)return false;
 97             }
 98         }
 99     return true;
100 }
101 int bfs()
102 {
103     mp.clear();
104     while(!q.empty())q.pop();
105     int tmp,now;
106     char ss1[10],ss2[10];
107     tmp=12345678; //初始是012345678
108     mp[tmp]=0;
109     q.push(tmp);
110     while(!q.empty())
111     {
112         tmp=q.front();
113         q.pop();
114         if(judge(tmp))return mp[tmp];
115         sprintf(ss1,"%09d",tmp);
116
117         for(int i=0;i<3;i++)
118           for(int j=0;j<3;j++)
119           {
120               int t=ss1[3*i+j]-‘0‘;
121              strcpy(g[i][j],str[t/3][t%3]);
122           }
123         //第一行的左右移动
124         if(move[0])
125         {
126             strcpy(ss2,ss1);
127             ss2[0]=ss1[1];
128             ss2[1]=ss1[2];
129             ss2[2]=ss1[0];
130             now=0;
131             for(int i=0;i<9;i++)
132             {
133                 now*=10;
134                 now+=ss2[i]-‘0‘;
135             }
136             if(mp.find(now)==mp.end())
137             {
138                 mp[now]=mp[tmp]+1;
139                 q.push(now);
140             }
141
142             ss2[0]=ss1[2];
143             ss2[1]=ss1[0];
144             ss2[2]=ss1[1];
145             now=0;
146             for(int i=0;i<9;i++)
147             {
148                 now*=10;
149                 now+=ss2[i]-‘0‘;
150             }
151             if(mp.find(now)==mp.end())
152             {
153                 mp[now]=mp[tmp]+1;
154                 q.push(now);
155             }
156
157         }
158
159         //第二行的左右移动
160         if(move[1])
161         {
162             strcpy(ss2,ss1);
163             ss2[3]=ss1[4];
164             ss2[4]=ss1[5];
165             ss2[5]=ss1[3];
166             now=0;
167             for(int i=0;i<9;i++)
168             {
169                 now*=10;
170                 now+=ss2[i]-‘0‘;
171             }
172             if(mp.find(now)==mp.end())
173             {
174                 mp[now]=mp[tmp]+1;
175                 q.push(now);
176             }
177             ss2[3]=ss1[5];
178             ss2[4]=ss1[3];
179             ss2[5]=ss1[4];
180             now=0;
181             for(int i=0;i<9;i++)
182             {
183                 now*=10;
184                 now+=ss2[i]-‘0‘;
185             }
186             if(mp.find(now)==mp.end())
187             {
188                 mp[now]=mp[tmp]+1;
189                 q.push(now);
190             }
191         }
192
193
194         //第三行的左右移动
195         if(move[2])
196         {
197             strcpy(ss2,ss1);
198             ss2[6]=ss1[7];
199             ss2[7]=ss1[8];
200             ss2[8]=ss1[6];
201             now=0;
202             for(int i=0;i<9;i++)
203             {
204                 now*=10;
205                 now+=ss2[i]-‘0‘;
206             }
207             if(mp.find(now)==mp.end())
208             {
209                 mp[now]=mp[tmp]+1;
210                 q.push(now);
211             }
212
213             ss2[6]=ss1[8];
214             ss2[7]=ss1[6];
215             ss2[8]=ss1[7];
216             now=0;
217             for(int i=0;i<9;i++)
218             {
219                 now*=10;
220                 now+=ss2[i]-‘0‘;
221             }
222             if(mp.find(now)==mp.end())
223             {
224                 mp[now]=mp[tmp]+1;
225                 q.push(now);
226             }
227
228         }
229
230
231         //第一列的左右移动
232         if(move[3])
233         {
234             strcpy(ss2,ss1);
235             ss2[0]=ss1[3];
236             ss2[3]=ss1[6];
237             ss2[6]=ss1[0];
238             now=0;
239             for(int i=0;i<9;i++)
240             {
241                 now*=10;
242                 now+=ss2[i]-‘0‘;
243             }
244             if(mp.find(now)==mp.end())
245             {
246                 mp[now]=mp[tmp]+1;
247                 q.push(now);
248             }
249
250             ss2[0]=ss1[6];
251             ss2[3]=ss1[0];
252             ss2[6]=ss1[3];
253             now=0;
254             for(int i=0;i<9;i++)
255             {
256                 now*=10;
257                 now+=ss2[i]-‘0‘;
258             }
259             if(mp.find(now)==mp.end())
260             {
261                 mp[now]=mp[tmp]+1;
262                 q.push(now);
263             }
264
265         }
266
267         //第二列的左右移动
268         if(move[4])
269         {
270             strcpy(ss2,ss1);
271             ss2[1]=ss1[4];
272             ss2[4]=ss1[7];
273             ss2[7]=ss1[1];
274             now=0;
275             for(int i=0;i<9;i++)
276             {
277                 now*=10;
278                 now+=ss2[i]-‘0‘;
279             }
280             if(mp.find(now)==mp.end())
281             {
282                 mp[now]=mp[tmp]+1;
283                 q.push(now);
284             }
285
286             ss2[1]=ss1[7];
287             ss2[4]=ss1[1];
288             ss2[7]=ss1[4];
289             now=0;
290             for(int i=0;i<9;i++)
291             {
292                 now*=10;
293                 now+=ss2[i]-‘0‘;
294             }
295             if(mp.find(now)==mp.end())
296             {
297                 mp[now]=mp[tmp]+1;
298                 q.push(now);
299             }
300
301         }
302
303         //第三列的左右移动
304         if(move[5])
305         {
306             strcpy(ss2,ss1);
307             ss2[2]=ss1[5];
308             ss2[5]=ss1[8];
309             ss2[8]=ss1[2];
310             now=0;
311             for(int i=0;i<9;i++)
312             {
313                 now*=10;
314                 now+=ss2[i]-‘0‘;
315             }
316             if(mp.find(now)==mp.end())
317             {
318                 mp[now]=mp[tmp]+1;
319                 q.push(now);
320             }
321
322             ss2[2]=ss1[8];
323             ss2[5]=ss1[2];
324             ss2[8]=ss1[5];
325             now=0;
326             for(int i=0;i<9;i++)
327             {
328                 now*=10;
329                 now+=ss2[i]-‘0‘;
330             }
331             if(mp.find(now)==mp.end())
332             {
333                 mp[now]=mp[tmp]+1;
334                 q.push(now);
335             }
336         }
337
338     }
339     return -1;
340 }
341
342 int main()
343 {
344     int T;
345     scanf("%d",&T);
346     int iCase=0;
347     while(T--)
348     {
349         iCase++;
350         printf("Case #%d: ",iCase);
351         for(int i=0;i<6;i++)move[i]=true;
352         for(int i=0;i<3;i++)
353           for(int j=0;j<3;j++)
354           {
355               scanf("%s",&str[i][j]);
356               if(str[i][j][4]==‘1‘)//所在的列和行不能移动
357               {
358                   move[i]=false;
359                   move[3+j]=false;
360               }
361           }
362         printf("%d\n",bfs());
363     }
364     return 0;
365 }
时间: 2024-10-13 09:52:35

hdu 4531 bfs(略难)的相关文章

hdu 1252 BFS

1 /* 2 题意:给出一个m*m矩阵表示的完全图,且每个点都有自环,每条边都有一种颜色:有三个玩家ABC的三张纸片分别初始在 3 某三个位置(可以重叠),纸片可以沿着边走一步,可以走的路径的规则为:若A要走到某个点i,则A-i的颜色要和B-C的颜 4 色相同:问最少要走多少步.(题意太难懂了,看了别人的说明才弄懂了题意) 5 6 题解:BFS 7 首先初步分析题意似乎很难用图论来解决,那么就是搜索/DP/数据结构,然后从搜索方面去思考的话,就是要找状态,然 8 后初步列出所有信息,三个点得位置

hdu 1175 bfs 转弯题

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1175 和之前的1728类似.就是判断转弯数,建立一个用于记录转弯数的数组.. 还有就是对于特殊情况要进行考虑,比如起点与终点相同的情况,对于本题来说是不可以消去的应该输出NO.还有就是起点或终点是零这也是不行的,因为0代表没有棋子... 还有在判断能不能走的时候要小心,对于判断条件一定要小心,不要图赶快写.. 错误的地方都写在注释中了.. 代码: // hdu 1175 bfs 转弯数 //1.起点

Saving Princess claire_(hdu 4308 bfs模板题)

http://acm.hdu.edu.cn/showproblem.php?pid=4308 Saving Princess claire_ Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 2305    Accepted Submission(s): 822 Problem Description Princess claire_ wa

HDU 1072 bfs

Nightmare Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 7083    Accepted Submission(s): 3409 Problem Description Ignatius had a nightmare last night. He found himself in a labyrinth with a tim

hdu 4707 bfs

bfs基础算法水题 #include<iostream> #include<cstdio> #include<cstring> #include<algorithm> #include<string> #include<vector> #include<queue> using namespace std; const int Max = 1e5+50; int dist[Max]; vector<int> t

hdu 5025 BFS + 优化 广东区域赛网赛

http://acm.hdu.edu.cn/showproblem.php?pid=5025 TLE了好几次 写的时候,问题在于, 1.钥匙怎么处理 参考了他人的写法,vis[key_num][i][j],相当于将图多维化,这样就可以判重了,否则只是按照普通的BFS,钥匙数不同的时候,可以重复,这个代码难易表达出来 另外此处一个很好的优化,当cost_now<cost[key_now][x_now][y_now]的时候,才q.push(Node)  这个剪枝很好啊 2.蛇怎么处理 没蛇的话,第一

hdu 5040 BFS 多维化处理图

http://acm.hdu.edu.cn/showproblem.php?pid=5040 跟这一题http://blog.csdn.net/u011026968/article/details/39586669 算是异曲同工. 所以比较容易想到了vis[4][MAXN][MAXN] 表示监控摄像头转4个方向 那个3秒跟蛇也很像,可是处理起来还有点麻烦,参考了这里: http://blog.csdn.net/hongrock/article/details/39472269 写的真不错: 方法

[hdu 2102]bfs+注意INF

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2102 感觉这个题非常水,结果一直WA,最后发现居然是0x3f3f3f3f不够大导致的--把INF改成INF+INF就过了. #include<bits/stdc++.h> using namespace std; bool vis[2][15][15]; char s[2][15][15]; const int INF=0x3f3f3f3f; const int fx[]={0,0,1,-1};

hdu 1226 BFS + bfs记录路径

http://acm.hdu.edu.cn/showproblem.php?pid=1226 为了省空间,可以用vis数组初始化的时候初始化为-1, 发现一个BFS容易错的地方 开始一直WA在这里:就是我int tp=q.front();之后马上q.pop():了,然后才去判断是不是符合条件以break,这样就不能根据q.empty()==1认为没有找到ans 因为这里WA了 其实也可以vis[0] == -1来判断 比较不理解的是 当n==0的时候 %n==0的时候怎么处理 //#pragma