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. Java SE 6 新特性: 编译器 API

    新 API 功能简介 JDK 6 提供了在运行时调用编译器的 API,后面我们将假设把此 API 应用在 JSP 技术中.在传统的 JSP 技术中,服务器处理 JSP 通常需要进行下面 6 个步骤: ...

  2. Java设计模式02:常用设计模式之工厂模式(创建型模式)

    一.工厂模式主要是为创建对象提供过渡接口,以便将创建对象的具体过程屏蔽隔离起来,达到提高灵活性的目的.  工厂模式在<Java与模式>中分为三类: 1)简单工厂模式(Simple Fact ...

  3. jQuery 获取文件后缀的方法

    var location=$("input[name='file']").val(); var point = location.lastIndexOf("." ...

  4. struts_ognl详解

  5. xpath 操作XML

    1.xpath 操作XML,底下部分代码被注释了,但是是完整功能,去除注释是正常使用的(有写命名和其他冲突,所以注释了) 总体有:完整读取xml,对xml的增删改查,对xml的特定操作 using S ...

  6. Cacti优化之spine轮询器

    由于效率的原因,在需要大量采集数据时,如果使用自带的cmd.php轮询器会比较慢,1分钟1次的采集频率可能无法完成轮询所有的被监控的机器,从而可能导致部分监控项目不出图或图形断断续续.为了解决效率问题 ...

  7. ILMerge合并程序

    在DOS窗口中,进入到ILMerge的安装目录 中 如图所示,之后写合并代码, 使用命令进行捆绑,以如图为例,将CSkin.dll和MyTool.exe捆绑成一个新的newtool.exe文件./ou ...

  8. angular.js 数字

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script sr ...

  9. ScheduleThreadPoolExecutor源码分析(二)

    DelayedWorkQueue: DelayedWorkQueue实现了BlockingQueue接口,因此其可以作为线程池的任务队列.BlockingQueue的主要属性有以下几个: privat ...

  10. pojo和JavaBean的区别

    javabean可以处理业务,pojo不可以. pojo就是get 和set 例如: Student{ id; name; get();... set();...} javabean可以实现业务逻辑 ...