Time Limit: 1000MS   Memory Limit: 65536K
Total Submissions: 8266   Accepted: 3507   Special Judge

Description

You are given two pots, having the volume of A and B liters respectively. The following operations can be performed:

  1. FILL(i)        fill the pot i (1 ≤ ≤ 2) from the tap;
  2. DROP(i)      empty the pot i to the drain;
  3. POUR(i,j)    pour from pot i to pot j; after this operation either the pot j is full (and there may be some water left in the pot i), or the pot i is empty (and all its contents have been moved to the pot j).

Write a program to find the shortest possible sequence of these operations that will yield exactly C liters of water in one of the pots.

Input

On the first and only line are the numbers AB, and C. These are all integers in the range from 1 to 100 and C≤max(A,B).

Output

The first line of the output must contain the length of the sequence of operations K. The following K lines must each describe one operation. If there are several sequences of minimal length, output any one of them. If the desired result can’t be achieved, the first and only line of the file must contain the word ‘impossible’.

Sample Input

3 5 4

Sample Output

6
FILL(2)
POUR(2,1)
DROP(1)
POUR(2,1)
FILL(2)
POUR(2,1) 题意:给定三个数A B C,前两个数代表容量为A和B的容器,有三种操作,FILL,DROP,POUR;求最少经过几次这样的操作可以得到容量为C的水; 思路:因为每个容器都有FILL,DROP,POUR三种操作,将两个容器的状态用队列来维护,两个容器共有六种操作的可能;
另一个关键是打印路径,可以用一个结构体数组保存前驱,通过栈再将路径打印出来;
 #include<stdio.h>
#include<string.h>
#include<algorithm>
#include<queue>
#include<stack>
//各种状态
#define FILL_A 1;
#define FILL_B 2;
#define DROP_A 3;
#define DROP_B 4;
#define POURA_B 5;
#define POURB_A 6;
using namespace std; struct node
{
int x,y;
int step;
};
queue<struct node>que; struct Path
{
int x,y;
int way;
}path[][];//保存前驱; int vis[][];
int a,b,c; //打印路径
void Print_Path(int x, int y)
{
stack<struct Path>st;
while(!st.empty())
st.pop(); while(!(x == && y == ))
{
st.push(path[x][y]);
int sx = path[x][y].x;
int sy = path[x][y].y;
x = sx;
y = sy;
} while(!st.empty())
{
switch(st.top().way)
{
case :printf("FILL(1)\n");break;
case :printf("FILL(2)\n");break;
case :printf("DROP(1)\n");break;
case :printf("DROP(2)\n");break;
case :printf("POUR(1,2)\n");break;
case :printf("POUR(2,1)\n");break;
}
st.pop();
}
} void bfs()
{
while(!que.empty())
que.pop();
que.push((struct node){,,});//初始状态进队列
vis[][] = ;
while(!que.empty())
{
struct node u = que.front();
que.pop();
if(u.x == c || u.y == c)
{
printf("%d\n",u.step);
Print_Path(u.x,u.y);
return;
}
//FILL_A
if(u.x < a && !vis[a][u.y])
{
vis[a][u.y] = ;
que.push((struct node){a,u.y,u.step+});
path[a][u.y] = (struct Path){u.x,u.y,};
}
//FILL_B
if(u.y < b && !vis[u.x][b])
{
vis[u.x][b] = ;
que.push((struct node){u.x,b,u.step+});
path[u.x][b] = (struct Path){u.x,u.y,};
}
//DROP_A
if(u.x > && !vis[][u.y])
{
vis[][u.y] = ;
que.push((struct node){,u.y,u.step+});
path[][u.y] = (struct Path){u.x,u.y,};
}
//DROP_B
if(u.y > && !vis[u.x][])
{
vis[u.x][] = ;
que.push((struct node){u.x,,u.step+});
path[u.x][] = (struct Path){u.x,u.y,};
}
//POURA_B
if(u.x < a && u.y > )
{
int tmp = min(a-u.x,u.y);
if(!vis[u.x+tmp][u.y-tmp])
{
vis[u.x+tmp][u.y-tmp] = ;
que.push((struct node){u.x+tmp,u.y-tmp,u.step+});
path[u.x+tmp][u.y-tmp] = (struct Path){u.x,u.y,};
}
}
//POURB_A
if(u.x > && u.y < b)
{
int tmp = min(u.x,b-u.y);
if(!vis[u.x-tmp][u.y+tmp])
{
vis[u.x-tmp][u.y+tmp] = ;
que.push((struct node){u.x-tmp,u.y+tmp,u.step+});
path[u.x-tmp][u.y+tmp] = (struct Path){u.x,u.y,};
}
}
}
printf("impossible\n");
}
int main()
{
scanf("%d %d %d",&a,&b,&c);
memset(vis,,sizeof(vis));
bfs();
return ;
}

Pots(bfs)的更多相关文章

  1. POJ 3414 Pots(BFS)

    Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%lld & %llu Description You are g ...

  2. poj 3414 Pots(bfs+输出路径)

    Description You are given two pots, having the volume of A and B liters respectively. The following ...

  3. POJ3414—Pots(bfs加回溯)

    http://poj.org/problem?id=3414                                       Pots Time Limit: 1000MS   Memor ...

  4. POJ - 3414 Pots BFS(著名倒水问题升级版)

    Pots You are given two pots, having the volume of A and B liters respectively. The following operati ...

  5. POJ3414 Pots —— BFS + 模拟

    题目链接:http://poj.org/problem?id=3414 Pots Time Limit: 1000MS   Memory Limit: 65536K Total Submissions ...

  6. POJ 3414 Pots (BFS/DFS)

    Pots Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7783   Accepted: 3261   Special Ju ...

  7. poj 3414 Pots bfs+模拟

    #include<iostream> #include<cstring> #define fillA 1 #define pourAB 2 #define dropA 3 #d ...

  8. POJ 3414 Pots bfs打印方案

    题目: http://poj.org/problem?id=3414 很好玩的一个题.关键是又16ms 1A了,没有debug的日子才是好日子.. #include <stdio.h> # ...

  9. POJ 3414 Pots ( BFS , 打印路径 )

    题意: 给你两个空瓶子,只有三种操作 一.把一个瓶子灌满 二.把一个瓶子清空 三.把一个瓶子里面的水灌到另一个瓶子里面去(倒满之后要是还存在水那就依然在那个瓶子里面,或者被灌的瓶子有可能没满) 思路: ...

随机推荐

  1. 我开启httpd服务的时候 显示Could not reliably determine the server`s fully qualified domain name,

    vi /etc/httpd/conf/httpd.conf加入一句 ServerName localhost:80

  2. PHP编译安装出错configure: error: mcrypt.h not found. Please reinstall libmcrypt的解决办法

    1.下载libmcrypt wget http://jaist.dl.sourceforge.net/project/mcrypt/Libmcrypt/2.5.8/libmcrypt-2.5.8.ta ...

  3. <thead>

    <thead> 标签定义表格表头该标签用于组合 HTML 表格表头内容 thead 元素应该与 tbody 和 tfoot 元素结合起来使用 tbody 元素用于对 HTML 表格主体内容 ...

  4. 《3D数学基础:图形与游戏开发》勘误

    最近读这本书,读到四元素的乘法时,自己推导了一下公式,然后懵了,多方查阅,确定是书籍中的笔误(我读的是中文翻译版): 具体在Page147: 上图所示,在第二处明显与第一处的公式不一样. 在维基百科上 ...

  5. Lambda表达式转SQL语句类库

    /* 作者:道法自然   * 个人邮件:myyangbin@sina.cn * 2014-10-1 */ Lambda表达式转SQL语句类库源码下载:http://download.csdn.net/ ...

  6. asp.net对word文档进行修改 对于使用word文档做模板编辑比较适用

    最近做项目,需要多word文档进行编辑并导出一个新的word,在最初的word编辑中留下特定的字符串用来替换,然后在本地生成一个新的word文档,并且不修改服务器中的word文档,这样才能保证服务器中 ...

  7. 微软企业库Microsoft Enterprise Library的相关文章链接

    微软企业库4.1学习笔记 http://blog.csdn.net/anyqu/article/category/1228691/3 黄聪:Enterprise Library 5.0 系列教程 ww ...

  8. php中调用其他系统http接口的方法说明

    使用函数: file_get_contents($url); 传入接口url及其参数:如 $url="http://192.168.1.1/test.jsp?id=1&type=2& ...

  9. Android布局管理器(线性布局)

    线性布局有LinearLayout类来代表,Android的线性布局和Swing的Box有点相似(他们都会将容器里面的组件一个接一个的排列起来),LinearLayout中,使用android:ori ...

  10. HDOJ 2036

    错误代码: #include<stdio.h>#include<math.h>int main(){ int x[102],y[102]; int i,n; float s,a ...