hdoj 1495 非常可乐【bfs隐式图】
非常可乐
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 8021 Accepted Submission(s):
3210
毫升和M 毫升 可乐的体积为S (S<101)毫升 (正好装满一瓶) ,它们三个之间可以相互倒可乐 (都是没有刻度的,且
S==N+M,101>S>0,N>0,M>0) 。聪明的ACMER你们说他们能平分吗?如果能请输出倒可乐的最少的次数,如果不能输出"NO"。
#include<stdio.h>
#include<string.h>
#include<queue>
#include<stack>
#include<algorithm>
#define INF 0x3f3f3f
#define MAX 100+10
using namespace std;
int s,n,m,k;
int map[MAX][MAX][MAX];
struct node
{
int a,b,c,step;
friend bool operator <(node x,node y)
{
return x.step>y.step;
}
};
void bfs()
{
node now,next;//用next表示上一次,now表示当前
priority_queue<node> q;
now.a=s;
now.b=0;
now.c=0;
now.step=0;
q.push(now);
map[now.a][now.b][now.c]=1;
while(!q.empty())
{
next=q.top();
q.pop();
if(next.a==k&&next.b==k||next.a==k&&next.c==k||next.b==k&&next.c==k)
{
printf("%d\n",next.step);
return ;
}
/*a杯子倒进b,c两个里面*/
/*先倒进b杯子里*/
if(next.b!=n&&next.a)//前提b杯子不能满
{
if(next.a>(n-next.b))// 把a杯子的水倒满b a还有剩余
{
now.a=next.a-(n-next.b);
now.b=n;
now.c=next.c;//c杯子不变
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;//记录状态
q.push(now);
}
}
else//a杯子水倒不满b
{
now.a=0;
now.b=next.a+next.b;
now.c=next.c;
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
}
}
}
/*倒进c杯子里面*/
if(next.c!=m&&next.a)//前提c杯子不能满 a杯子水不能为空
{
if(next.a>(m-next.c))//倒满还有剩余
{
now.a=next.a-(m-next.c);
now.b=next.b;//b杯子不变
now.c=m;
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
}
}
else//倒不满
{
now.a=0;
now.b=next.b;
now.c=next.c+next.a;
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
}
}
}
/*b杯子水倒进a,c里面*/
/*先倒进a*/
if(next.b&&next.a!=s)//b杯子水不能为空 且a杯子水不能满
{
if(next.b>(s-next.a))//倒满还有剩余
{
now.a=s;
now.b=next.b-(s-next.a);
now.c=next.c;
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
}
}
else//倒不满
{
now.a=next.b+next.a;
now.b=0;
now.c=next.c;
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
}
}
}
/*倒进c*/
if(next.b&&next.c!=m)//b杯子水不能为空 且c杯子水不能满
{
if(next.b>(m-next.c))//倒满还有剩余
{
now.a=next.a;
now.b=next.b-(m-next.c);
now.c=m;
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
}
}
else//倒不满
{
now.a=next.a;
now.b=0;
now.c=next.c+next.b;
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
}
}
}
/*c杯子倒进a,b里面*/
/*先 a*/
if(next.c&&next.a!=s)
{
if(next.c>(s-next.a))//倒满还有剩余
{
now.a=s;
now.b=next.b;
now.c=next.c-(s-next.a);
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
}
}
else//倒不满a
{
now.a=next.a+next.c;
now.b=next.b;
now.c=0;
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
} }
}
/*倒进b*/
if(next.c&&next.b!=n)
{
if(next.c>(n-next.b))//倒满还有剩余
{
now.a=next.a;
now.b=n;
now.c=next.c-(n-next.b);
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
}
}
else//倒不满b
{
now.a=next.a;
now.b=next.b+next.c;
now.c=0;
if(!map[now.a][now.b][now.c])//没有出现该状态
{
now.step=next.step+1;
map[now.a][now.b][now.c]=1;
q.push(now);
}
}
}
}
printf("NO\n");
}
int main()
{
int t,i,j,sum;
while(scanf("%d%d%d",&s,&n,&m)&&(s!=0||n!=0||m!=0))
{
if(s&1)
{
printf("NO\n");
continue;
}
memset(map,0,sizeof(map));
k=s/2;
bfs();
}
return 0;
}
hdoj 1495 非常可乐【bfs隐式图】的更多相关文章
- 八数码问题+路径寻找问题+bfs(隐式图的判重操作)
Δ路径寻找问题可以归结为隐式图的遍历,它的任务是找到一条凑够初始状态到终止问题的最优路径, 而不是像回溯法那样找到一个符合某些要求的解. 八数码问题就是路径查找问题背景下的经典训练题目. 程序框架 p ...
- HDOJ 1495 非常可乐 【BFS】
非常可乐 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- nyoj 21--三个水杯(隐式图bfs)
三个水杯 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 给出三个水杯,大小不一,并且只有最大的水杯的水是装满的,其余两个为空杯子.三个水杯之间相互倒水,并且水杯没有标识 ...
- 【UVA】658 - It's not a Bug, it's a Feature!(隐式图 + 位运算)
这题直接隐式图 + 位运算暴力搜出来的,2.5s险过,不是正法,做完这题做的最大收获就是学会了一些位运算的处理方式. 1.将s中二进制第k位变成0的处理方式: s = s & (~(1 < ...
- uva658(最短路径+隐式图+状态压缩)
题目连接(vj):https://vjudge.net/problem/UVA-658 题意:补丁在修正 bug 时,有时也会引入新的 bug.假定有 n(n≤20)个潜在 bug 和 m(m≤100 ...
- UVA 658 状态压缩+隐式图+优先队列dijstla
不可多得的好题目啊,我看了别人题解才做出来的,这种题目一看就会做的实在是大神啊,而且我看别人博客都看了好久才明白...还是对状态压缩不是很熟练,理解几个位运算用了好久时间.有些题目自己看着别人的题解做 ...
- UVA - 658 It's not a Bug, it's a Feature! (隐式图的最短路,位运算)
隐式的图搜索,存不下边,所以只有枚举转移就行了,因为bug的存在状态可以用二进制表示,转移的时候判断合法可以用位运算优化, 二进制pre[i][0]表示可以出现的bug,那么u&pre[i][ ...
- UVa 10603 Fill (BFS && 经典模拟倒水 && 隐式图)
题意 : 有装满水的6升的杯子.空的3升杯子和1升杯子,3个杯子中都没有刻度.不使用道具情况下,是否可量出4升水呢? 你的任务是解决一般性的问题:设3个杯子的容量分别为a, b, c,最初只有第3个杯 ...
- HDU 1495 非常可乐 BFS 搜索
http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目就不说了, 说说思路! 倒可乐 无非有6种情况: 1. S 向 M 倒 2. S 向 N 倒 3. N ...
随机推荐
- Codeforces Round #361 div2
ProblemA(Codeforces Round 689A): 题意: 给一个手势, 问这个手势是否是唯一. 思路: 暴力, 模拟将这个手势上下左右移动一次看是否还在键盘上即可. 代码: #incl ...
- Spring 数据源配置一:单一数据源
最近遇到一个项目,需要访问都多个数据源,并且数据库是不同厂商(mysql, sqlserver). 所以对此做了一些研究,这里咱们采用渐进的方式来展开,先谈谈单一数据源配置.(稍后有时间会陆续补充其 ...
- 华为机试题——数组排序,且奇数存在奇数位置,偶数存在偶数位置
题目要求很简单,就是给你一个数组,对它进行排序,并且排序后,奇数要放在奇数的位置上,偶数要放在偶数的位置上,如果不满足这个规则的话就在数组上填充0 实现代码如下,文中值得注意的一点就是如何判读这个数字 ...
- [HDOJ - 5282] Senior's String 【DP】
题目链接:BZOJ - 5282 题目分析 LCS 就是用经典的 O(n^2) DP 解决,f[i][j] 表示 x 串前 i 个字符与 y 串前 j 个字符的 LCS 长度. f[i][j] = m ...
- responsive design
http://www.chinaz.com/manage/2011/1121/221607.shtml http://alistapart.com/article/responsive-web-des ...
- U3D版本《暗黑世界V1.0》编译——图文教程!
原地址:http://blog.csdn.net/uxqclm/article/details/11970773 欢迎来到9秒:www.9miao.com 说明: A. 工具准备: ...
- UPUPW PHP环境集成包
UPUPW PHP环境集成包 http://www.upupw.net/
- POJ 1364 King
http://poj.org/problem?id=1364 题意 :给出一个序列a1,a2,a3,a4.....ai,......at ;然后给你一个不等式使得ai+a(i+1)+a(i+2)+.. ...
- SEO 网站页面SEO优化之页面title标题优化
在seo优化中,标题的优化占着举足轻重的地位,无论是从用户体验的角度出发,还是从搜索引擎的排名效果出发,title标题都是页面优化最最重要的因素.笔者总结了优化title标题应该注意的六个方面: ①. ...
- asp.net上传图片(简单)
FileUpload: protected void UploadButton_Click(object sender, EventArgs e) { : Convert.ToInt64(Reques ...