poj 3414 路径输出的bfs(pre)

  1. #include <iostream>  
  2. #include <algorithm>  
  3. using namespace std;  
  4. #include <cstring>  
  5. #include <queue>  
  6. #include <stack>  
  7. struct cup  
  8. {  
  9.     int x, y;  
  10.     int step;  
  11.     int flag;//标记操作  
  12.     cup *pre;//记录路径  
  13. };  
  14. queue<cup>Q;  
  15. stack<int>R;  
  16. int a, b, e;  
  17. int vis[117][117]={0};//标记当前状态是否到达过  
  18. int ans;  
  19. void BFS(int x, int y)  
  20. {  
  21.     cup c;  
  22.     cup t[317];//目前瓶子里剩余的水量  
  23.     c.x = 0, c.y = 0;  
  24.     c.flag = 0;  
  25.     c.pre = NULL;  
  26.     c.step = 0;  
  27.     Q.push(c);  
  28.     vis[x][y] = 1;  
  29.     int count = -1;  
  30.     while(!Q.empty())  
  31.     {  
  32.         count++;  
  33.         t[count] = Q.front();  
  34.         Q.pop();  
  35.         for(int i = 1; i <= 6; i++)  
  36.         {  
  37.             switch(i)  
  38.             {  
  39.                 case 1:                     //fill a  
  40.                     c.x = a;  
  41.                     c.y = t[count].y;  
  42.                     c.flag = 1;  
  43.                     break;  
  44.                 case 2:                     //fill b  
  45.                     c.x = t[count].x;  
  46.                     c.y = b;  
  47.                     c.flag = 2;  
  48.                     break;  
  49.                 case 3:                     //drop a  
  50.                     c.x = 0;  
  51.                     c.y = t[count].y;  
  52.                     c.flag = 3;  
  53.                     break;  
  54.                 case 4:                     //drop b  
  55.                     c.x = t[count].x;  
  56.                     c.y = 0;  
  57.                     c.flag = 4;  
  58.                     break;  
  59.                 case 5:                     //pour a to b  
  60.                     if(t[count].x > b-t[count].y)  
  61.                     {  
  62.                         c.x = t[count].x-(b-t[count].y);  
  63.                         c.y = b;  
  64.                     }  
  65.                     else  
  66.                     {  
  67.                         c.x = 0;  
  68.                         c.y = t[count].y+t[count].x;  
  69.                     }  
  70.                     c.flag = 5;  
  71.                     break;  
  72.                 case 6:                     //pour b to a  
  73.                     if(t[count].y > a-t[count].x)  
  74.                     {  
  75.                         c.y = t[count].y - (a-t[count].x);  
  76.                         c.x = a;  
  77.                     }  
  78.                     else  
  79.                     {  
  80.                         c.x = t[count].x+t[count].y;  
  81.                         c.y = 0;  
  82.                     }  
  83.                     c.flag = 6;  
  84.                     break;  
  85.             }  
  86.             if(vis[c.x][c.y])  
  87.                 continue;  
  88.             vis[c.x][c.y] = 1;  
  89.             c.step = t[count].step+1;  
  90.             c.pre = &t[count];  
  91.             if(c.x == e || c.y == e)  
  92.             {  
  93.                 ans = c.step;  
  94.                 while(c.pre)  
  95.                 {  
  96.                     R.push(c.flag);  
  97.                     c = *c.pre;  
  98.                 }  
  99.                 return;  
  100.             }  
  101.             Q.push(c);  
  102.         }  
  103.     }  
  104. }  
  105. void print()  
  106. {  
  107.     while(!R.empty())  
  108.     {  
  109.         int i = R.top();  
  110.         R.pop();  
  111.         switch(i)  
  112.         {  
  113.             case 1:cout<<"FILL(1)"<<endl;break;  
  114.             case 2:cout<<"FILL(2)"<<endl;break;  
  115.             case 3:cout<<"DROP(1)"<<endl;break;  
  116.             case 4:cout<<"DROP(2)"<<endl;break;  
  117.             case 5:cout<<"POUR(1,2)"<<endl;break;  
  118.             case 6:cout<<"POUR(2,1)"<<endl;break;  
  119.         }  
  120.     }  
  121. }  
  122. int main()  
  123. {  
  124.     cin >>a>>b>>e;  
  125.     BFS(0,0);  
  126.     if(ans == 0)  
  127.         cout<<"impossible"<<endl;  
  128.     else  
  129.     {  
  130.         cout<<ans<<endl;  
  131.         print();  
  132.     }  
  133.     return 0;  
  134. }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
POJ2251是一个经典的题目,也被称为"水仙花的谜题"。该题目要求在一个三维的迷宫中找到从起点到终点的最短路径。 在这个题目中,迷宫由一个3D的数组表示,每个位置上的值代表了该位置的状态。其中,0表示可以通过的路径,1表示墙壁,2表示起点,3表示终点。你需要编写一个程序来找到从起点到终点的最短路径,并输出路径的长度。 解决这个问题的一种常见方法是使用广度优先搜索(BFS)算法。BFS算法可以从起点开始,逐层遍历迷宫中的位置,直到找到终点或者遍历完所有可达位置。在遍历过程中,你需要记录每个位置的距离和路径信息,以便找到最短路径。 以下是解决该问题的大致思路: 1. 定义一个队列,将起点加入队列,并标记起点已访问。 2. 使用循环来遍历队列中的元素,直到队列为空。 3. 在循环中,取出队列中的元素,并获取其相邻可达位置。 4. 对于每个相邻位置,判断是否为终点,如果是则输出最短路径长度并结束程序。 5. 如果不是终点,则判断该位置是否为可通过的路径,并且未被访问过。如果满足条件,则将该位置加入队列,并更新距离和路径信息。 6. 重复步骤2-5,直到找到终点或者遍历完所有可达位置。 这只是一个简单的介绍,实际解决该问题还需要考虑一些细节,比如如何表示迷宫、如何判断位置的合法性等。你可以在编写代码时参考相关的算法和数据结构知识。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值