本题传送门

本题知识点:宽度优先搜素 + 字符串

题意很简单,如何把用两个杯子,装够到第三个杯子的水。

操作有六种,这样就可以当作是bfs的搜索方向了

// FILL(1) 把第一个杯子装满
// FILL(2) 把第二个杯子装满
// POUR(1,2) 把第一个杯子的水倒进第二个杯子
// POUR(2,1) 把第二个杯子的水倒进第一个杯子
// DROP(1) 把第一个杯子的水都倒掉
// DROP(2) 把第二个杯子的水都倒掉

本题的难点是如何记录路径,我们可以用一个巧妙的方法去解决掉,详细请看代码

// POJ 3414
#include<iostream>
#include<cstdio>
#include<string>
#include<queue>
using namespace std; bool take[102][102], ok;
int A, B, C;
struct node{
string str;
int l, r, pla[102], cnt; // cnt 记录有多少条路径
};
queue<node> que;
string str[] = {
"FILL(1)",
"FILL(2)",
"POUR(1,2)",
"POUR(2,1)",
"DROP(1)",
"DROP(2)"
}; void show(int len, int pla[]){
printf("%d\n", len);
for(int i = 1; i <= len; i++){
cout << str[pla[i]] << endl;
}
} void bfs(){
ok = false;
take[0][0] = true;
node a;
a.str = "NONE";
a.l = a.r = a.cnt = 0;
que.push(a); while(!que.empty()){
node next, now = que.front(); que.pop(); // cout << now.str << " ";
// printf("l:%d r:%d cnt:%d\n", now.l, now.r, now.cnt);
// show(now.cnt, now.pla);
// cout << endl; if(now.l == C || now.r == C){
show(now.cnt, now.pla);
ok = true;
break;
} // FILL(1)
if(now.l < A && !take[A][now.r]){
next.str = str[0];
next.l = A;
next.r = now.r;
// 这句循环是为了保存之前的路径 下同
for(int i = 1; i <= now.cnt; i++){
next.pla[i] = now.pla[i];
}
next.pla[now.cnt + 1] = 0;
next.cnt = now.cnt + 1;
take[A][now.r] = true;
que.push(next);
} // FILL(2)
if(now.r < B && !take[now.l][B]){
next.str = str[1];
next.l = now.l;
next.r = B;
for(int i = 1; i <= now.cnt; i++){
next.pla[i] = now.pla[i];
}
next.pla[now.cnt + 1] = 1;
next.cnt = now.cnt + 1;
take[now.l][B] = true;
que.push(next);
} // POUR(1, 2)
if(0 < now.l && now.r < B){
int R = now.l + now.r >= B ? B : now.l + now.r;
int L = R - now.r >= now.l ? 0 : now.l - (R - now.r);
if(!take[L][R]){
next.str = str[2];
next.l = L;
next.r = R;
for(int i = 1; i <= now.cnt; i++){
next.pla[i] = now.pla[i];
}
next.pla[now.cnt + 1] = 2;
next.cnt = now.cnt + 1;
take[L][R] = true;
que.push(next);
}
} // POUR(2,1)
if(now.l < A && 0 < now.r){
int L = now.l + now.r >= A ? A : now.l + now.r;
int R = L - now.l >= now.r ? 0 : now.r - (L - now.l);
if(!take[L][R]){
next.str = str[3];
next.l = L;
next.r = R;
for(int i = 1; i <= now.cnt; i++){
next.pla[i] = now.pla[i];
}
next.pla[now.cnt + 1] = 3;
next.cnt = now.cnt + 1;
take[L][R] = true;
que.push(next);
}
} // DROP(1)
if(!take[0][now.r]){
next.str = str[4];
next.l = 0;
next.r = now.r;
for(int i = 1; i <= now.cnt; i++){
next.pla[i] = now.pla[i];
}
next.cnt = now.cnt + 1;
next.pla[now.cnt + 1] = 4;
take[0][now.r] = true;
que.push(next);
} // DROP(2)
if(!take[now.l][0]){
next.str = str[5];
next.l = now.l;
next.r = 0;
for(int i = 1; i <= now.cnt; i++){
next.pla[i] = now.pla[i];
}
next.cnt = now.cnt + 1;
next.pla[now.cnt + 1] = 5;
take[now.l][0] = true;
que.push(next);
} } if(!ok) printf("impossible\n");
} int main()
{
scanf("%d %d %d", &A, &B, &C); bfs(); return 0;
}

【POJ3414】Pots的更多相关文章

  1. 【BFS】Pots

    [poj3414]Pots Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 16925   Accepted: 7168   ...

  2. 【转】ACM训练计划

    [转] POJ推荐50题以及ACM训练方案 -- : 转载自 wade_wang 最终编辑 000lzl POJ 推荐50题 第一类 动态规划(至少6题, 和 必做) 和 (可贪心) (稍难) 第二类 ...

  3. Python高手之路【六】python基础之字符串格式化

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...

  4. 【原】谈谈对Objective-C中代理模式的误解

    [原]谈谈对Objective-C中代理模式的误解 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这篇文章主要是对代理模式和委托模式进行了对比,个人认为Objective ...

  5. 【原】FMDB源码阅读(三)

    [原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...

  6. 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新

    [原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...

  7. 【调侃】IOC前世今生

    前些天,参与了公司内部小组的一次技术交流,主要是针对<IOC与AOP>,本着学而时习之的态度及积极分享的精神,我就结合一个小故事来初浅地剖析一下我眼中的“IOC前世今生”,以方便初学者能更 ...

  8. Python高手之路【三】python基础之函数

    基本数据类型补充: set 是一个无序且不重复的元素集合 class set(object): """ set() -> new empty set object ...

  9. Python高手之路【一】初识python

    Python简介 1:Python的创始人 Python (英国发音:/ˈpaɪθən/ 美国发音:/ˈpaɪθɑːn/), 是一种解释型.面向对象.动态数据类型的高级程序设计语言,由荷兰人Guido ...

随机推荐

  1. C# VB .net读取识别条形码线性条码codabar

    codabar是比较常见的条形码编码规则类型的一种.如何在C#,vb等.NET平台语言里实现快速准确读取codabar条形码呢?答案是使用SharpBarcode! SharpBarcode是C#快速 ...

  2. 简约而不简单的Django2.2 新手图文教程

     欢迎大家访问我的个人网站<刘江的博客和教程>www.liujiangblog.com  主要分享Python 及Django教程以及相关的博客! 版权所有,转载需注明来源! 2019年7 ...

  3. Java自学-类和对象 this

    Java 中的 this this 这个关键字,相当于普通话里的"我" 小明说 "我吃了" 这个时候,"我" 代表小明 小红说 " ...

  4. 计算n阶乘中尾部零的个数

    大佬答案 大佬的思路看了好久,每次看都会明白一丢丢,现在还有不明白的地方,但是要往后继续加油了,知新温故. 结论:参与阶乘的所有数的因子中只要存在一个2和一个5就会在阶乘的结果中产生一个0. 又因为因 ...

  5. [Flutter] 实现Flutter App内更新

    app内实现根据安卓和IOS平台进行更新 时间匆忙,相关操作以及信息都写在代码注释里面了,闲时在补充和完善. 功能在android项目中测试可用,ios上还未进行测试,如果ios有问题或者没问题的话都 ...

  6. 单词diamaund钻石diamaund英文

    Diamond Di"a*mond (?; 277), n. [OE. diamaund, the hardest iron, steel, diamond, Gr. . Perh. the ...

  7. idea git提交代码步骤(转载)

    参考一: https://blog.csdn.net/u013452337/article/details/79956604

  8. 机器学习笔记6:K-Means

    目录 目标函数 目标函数的表现函数 针对u和r求解: 最优解的表达式的意义: K-means聚类的形象化展示 聚类前 第一轮循环 第二轮循环 第三轮循环 最终结果 演示代码: 关于K-means的几个 ...

  9. jperf windows

    jperf windows版是款简单实用的网络性能测试的工具:它也是款图形界面的iperf程序,可以这进行使用JPerf程序的时候,快速的进行简化您的命令行参数,而且这进行测试结束之后,还是以图形化的 ...

  10. centos 7 新机器安装部署配置

    首先卸载openjdk,安装jdk 1.查看java版本 [lambert@localhost ~]$ java -version openjdk version "1.8.0_102&qu ...