poj1066 Jugs

http://poj.org/problem?id=1606

解题思路:本题可以用数学方法解得,最易理解,常规的解法是搜索。直接用接近模拟的广度优先搜索即可过。

给两个容器,给出最大容量(ca,cb)和目标水量n,可以执行6种操作:

(1)把A容器灌满水,操作名:fill A;

(2)把B容器灌满水,操作名:fill B;

(3)把A容器中的水倒出去,管它倒到哪里去,反正不在这两个容器里面,操作名:empty A;

(4)把B容器中的水倒出去,操作名:empty B;

(5)把A容器中的水倒到B容器中去,要是B容器装不下A容器中的水,则把B容器倒满,剩下的水留在A容器中,操作名:pour A B;

(6)把B容器中得水倒到A容器中去,,操作名:pour B A ;

要求最后留在B容器中的水量为n。

按操作的顺序输出操作名,使B容器中的水量为n。

直接用广度优先搜索即可,只是搜索时的搜索树,不是经典地图搜索中的四个方向,而是6种操作方法。

(1)定义ca,cb,n,分别用于A容器,B容器的最大装水量和目的水量;定义一个二维数组flag[1002][1002],用于存储A容器B容器装的水的量用于搜索是的状态判重,定义一个串数组存储6种操作名,用于后面输出操作名;定义一个结构体,内涵a,b,s,分别表示A容器,B容器上次操作后的装水量,和以前所处理的操作的操作名在用于输出的操作名的数组中的下标。

(2)对于每组测试案例,直接输入三个值,直到文件结束,程序终止。

(3)对于每组测试数据,进行广度优先搜索,每次搜索都分成6种操作方法对两个容器中的水量进行处理,当B容器中的水量为n时停止搜索,按照当前处理的状态结构体中的S串输出操作顺序的操作名即可。

(4)别忘了在每组数据最后输出“success”。

由于是用广度优先搜索算法进行搜索的,故搜索到的操作次数必是最小的,无需再判断次数。

注:本题是特殊对比方式判正误,即使样例输入得到的的答案和样例输出的内容有所不用也不要紧,只要后面B容器中得水的量是n的即可。

12052890 20114045007 1606 Accepted 4100K 16MS C++ 1883B 2013-08-29 19:47:08
#include<stdio.h>
#include<iostream>
#include<string.h>
#include<string>
#include<queue>
using namespace std;
int ca,cb,n;
int flag[1002][1002]; //状态标记,用于判重
string out[]={"fill A","fill B","empty A","empty B","pour A B","pour B A"}; //6个操作名
struct node
{
int a;
int b;
string s;
};
void bfs()
{
memset(flag,0,sizeof(flag));
node now,next;
queue<node> q;
now.a=0;
now.b=0;
flag[0][0]=1;
q.push(now);
while(!q.empty())
{
now=q.front();
q.pop();
if(now.b==n) //B容器中得水量为n时,搜索成功
 {
for(int i=0;i<now.s.size();i++)
cout<<out[now.s[i]-'0']<<endl;
return;
}
//fill A
next.a=ca;
next.b=now.b;
next.s=now.s+'0';
if(!flag[next.a][next.b])flag[next.a][next.b]=1,q.push(next);
next.a=now.a;
next.b=cb;
next.s=now.s+'1';
if(!flag[next.a][next.b])flag[next.a][next.b]=1,q.push(next);
//empty A
next.a=0;
next.b=now.b;
next.s=now.s+'2';
if(!flag[next.a][next.b])flag[next.a][next.b]=1,q.push(next);
//empty B
next.a=now.a;
next.b=0;
next.s=now.s+'3';
if(!flag[next.a][next.b])flag[next.a][next.b]=1,q.push(next);
//pour A B
if(cb-now.b>=now.a)next.a=0,next.b=now.b+now.a; //若B容器中还可装入的水量大于等于A容器中当前水量,则把A容器中的水全部倒入B容器中
else next.a=now.a-cb+now.b,next.b=cb; //否则,把B容器倒满,剩下的水留在A容器中
next.s=now.s+'4';
if(!flag[next.a][next.b])flag[next.a][next.b]=1,q.push(next);
// pour B A
if(ca-now.a>=now.b)next.b=0,next.a=now.a+now.b; //同上
else next.b=now.b-ca+now.a,next.a=ca;
next.s=now.s+'5';
if(!flag[next.a][next.b])flag[next.a][next.b]=1,q.push(next);
}
}
int main()
{
while(scanf("%d%d%d",&ca,&cb,&n)!=EOF)
{
bfs();
printf("success\n");
}
return 0;
}

poj1066 Jugs的更多相关文章

  1. ZOJ 1005:Jugs(思维)

    Jugs Time Limit: 2 Seconds      Memory Limit: 65536 KB      Special Judge In the movie "Die Har ...

  2. 【Acm】算法之美—Jugs

    题目概述:Jugs In the movie "Die Hard 3", Bruce Willis and Samuel L. Jackson were confronted wi ...

  3. POJ1066线段交点

    POJ1066 题意:给出一个100*100的正方形区域,通过若干连接区域边界的线段将正方形区域分割为多个不规则多边形小区域,然后给出宝藏位置,要求从区域外部开辟到宝藏所在位置的一条路径,使得开辟路径 ...

  4. Jugs(回溯法)

    ZOJ Problem Set - 1005 Jugs Time Limit: 2 Seconds      Memory Limit: 65536 KB      Special Judge In ...

  5. 『ACM C++』HDU杭电OJ | 1415 - Jugs (灌水定理引申)

    今天总算开学了,当了班长就是麻烦,明明自己没买书却要带着一波人去领书,那能怎么办呢,只能说我善人心肠哈哈哈,不过我脑子里突然浮起一个念头,大二还要不要继续当这个班委呢,既然已经体验过就可以适当放下了吧 ...

  6. poj1066(叉乘的简单应用)

    做完了才发现,好像没有人和我的做法一样的,不过我怎么都觉得我的做法还是挺容易想的. 我的做法是: 把周围的方框按顺时针编号,然后对于每一条边,如果点出现在边的一侧,则把另一侧所有的点加1,这样最后统计 ...

  7. 九度OJ 1147:Jugs(罐子) (模拟、游戏)

    时间限制:1 秒 内存限制:32 兆 特殊判题:是 提交:243 解决:200 题目描述: In the movie "Die Hard 3", Bruce Willis and ...

  8. UVA571 - Jugs(数论)

    UVA571 - Jugs(数论) 题目链接 题目大意:给你A和B的水杯.给你三种操作:fill X:把X杯里面加满水.empty X:把X杯中的水清空.pour X Y 把X的水倒入Y中直到一方满或 ...

  9. POJ 1606 Jugs

    Jugs Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 4280   Accepted: 2533   Special Ju ...

随机推荐

  1. 笔记之Cyclone IV第一卷第三章器件中的存储器模块

    嵌入式存储器结构由一列列 M9K 存储器模块组成,通过对这些 M9K 存储器模块进行配置,可以实现各种存储器功能,例如:RAM.移位寄存器. ROM 以及FIFO 缓冲器. M9K 存储器模块支持以下 ...

  2. PHP脚本实现凯撒加(解)密

    原文:PHP脚本实现凯撒加(解)密 今天在看某ctf时候遇到一题凯撒加密的题,然后看到write up里有这样一句 顿时感觉这题目有点坑啊,这要不写个脚本来跑要推到啥时候啊,于是又了本文: <? ...

  3. python爬虫实战2百度贴吧爬html

    转自:http://blog.csdn.net/wxg694175346/article/details/8927832 import string, urllib2 #定义百度函数 def baid ...

  4. 基于visual Studio2013解决C语言竞赛题之0413同构数

       题目 解决代码及点评 该题目与水仙花数类似,只是条件不同,循环还是一样的 /***************************************************** ...

  5. 基于visual Studio2013解决C语言竞赛题之0516人来人往

     题目

  6. Json也可以这么使

    public string GetJSON() { //Json数据 string json112 = "{\"control_info\":{\"imei\& ...

  7. C-整数划分

    将正整数 n 表示成一系列正整数之和, n=n1+n2+…+nk, 其中 n1>=n2>=…>=nk>=1 , k>=1 . 正整数 n 的这种表示称为正整数 n 的划分 ...

  8. 清华集训2014 day2 task3 矩阵变换

    题目 算法 稳定婚姻系统(其实就是贪心) 一个方案不合法,当且仅当下面这种情况: 设第\(i\)行选了数字\(x\),如果第\(j\)行有一个\(x\)在第\(i\)行的\(x\)后面,并且第\(j\ ...

  9. 【Cron Expressions】Quartz Scheduler 2.1.x 英文节选

    Cron Expressions Cron-Expressions are used to configure instances ofCronTrigger. Cron-Expressions ar ...

  10. mpi中利用自定义归约操作实现merge

    在归并排序中,很重要的一步是将两个排序数组合并成一个数组,这个操作叫merge.merge操作可以用来解决某些Top K问题. 问题描述 在哼唱搜索中,用户通过哼唱一个音乐片段去搜索与其相似的音乐.后 ...