非常可乐 HDU - 1495
Input三个整数 : S 可乐的体积 , N 和 M是两个杯子的容量,以"0 0 0"结束。Output如果能平分的话请输出最少要倒的次数,否则输出"NO"。Sample Input
7 4 3
4 1 3
0 0 0
Sample Output
NO
3 思路:很明显的状态转移BFS S->N S->M N->S N->M M->S M->N
AC Code:
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define N 100+5
using namespace std; struct node{
int a,b,s,t;
}cole[N],st; int a,b,s;
int vis[N][N]; //记录状态(二维就可以记录三维的状态)。
int bfs()
{
queue<node> q;
memset(vis,,sizeof(vis));
st.a=; st.b=; st.s=s; st.t=;
q.push(st);
vis[a][b]=;
while(!q.empty())
{
node u=q.front(),v;
//能平分的条件是可乐瓶和容量大(a)的杯子都装着最开始一半的可乐。
if(u.a==s/ && u.s==s/)
return u.t;
if(u.s && u.a!=a) //s->a
{
int c=a-u.a;
if(u.s>=c) v.a=a,v.s=u.s-c;
else v.a=u.a+u.s,v.s=;
v.b=u.b; v.t=u.t+;
if(!vis[v.a][v.b]) //只从之前没有出现的状态往下推,下同。
{
q.push(v);
vis[v.a][v.b]=;
}
}
if(u.s && u.b!=b) //s->b
{
int c=b-u.b;
if(u.s>=c) v.b=b,v.s=u.s-c;
else v.b=u.b+u.s,v.s=;
v.a=u.a; v.t=u.t+;
if(!vis[v.a][v.b])
{
q.push(v);
vis[v.a][v.b]=;
}
}
if(u.a && u.s!=s) //a->s
{
int c=s-u.s;
if(u.a>=c) v.s=s,v.a=u.a-c;
else v.s=u.s+u.a,v.a=;
v.b=u.b; v.t=u.t+;
if(!vis[v.a][v.b])
{
q.push(v);
vis[v.a][v.b]=;
}
}
if(u.a && u.b!=b) //a->b
{
int c=b-u.b;
if(u.a>=c) v.b=b,v.a=u.a-c;
else v.b=u.b+u.a,v.a=;
v.s=u.s; v.t=u.t+;
if(!vis[v.a][v.b])
{
q.push(v);
vis[v.a][v.b]=;
}
}
if(u.b && u.a!=a) //b->s
{
int c=a-u.a;
if(u.b>=c) v.a=a,v.b=u.b-c;
else v.a=u.a+u.b,v.b=;
v.s=u.s; v.t=u.t+;
if(!vis[v.a][v.b])
{
q.push(v);
vis[v.a][v.b]=;
}
}
if(u.b && u.s!=s) //b->a
{
int c=s-u.s;
if(u.b>=c) v.s=s,v.b=u.b-c;
else v.s=u.s+u.b,v.b=;
v.a=u.a; v.t=u.t+;
if(!vis[v.a][v.b])
{
q.push(v);
vis[v.a][v.b]=;
}
}
q.pop();
}
return ; //所有扩展的状态都不能使之平分。
}
int main()
{
while(scanf("%d%d%d",&s,&a,&b),s||a||b)
{
if(s%)
{
puts("NO");
continue;
}
if(a<b) swap(a,b); //这里使a作大号杯,方便bfs条件的判定。
int ans=bfs();
if(ans) printf("%d\n",ans);
else puts("NO");
}
return ;
}
//第二次做发现 : 1. 要标记已经走过的状态
2. 即使在 S % 2 ==0 下也有可能无法平分的。
非常可乐 HDU - 1495的更多相关文章
- 非常可乐---hdu 1495(BFS)
http://acm.hdu.edu.cn/showproblem.php?pid=1495 题意: 有3个杯子a b c:a=b+c:然后刚开始时只有a是满的,其它为空的,然后a b c三个之间互相 ...
- kuangbin专题 专题一 简单搜索 非常可乐 HDU - 1495
题目链接:https://vjudge.net/problem/HDU-1495 题意:有两个空杯(分别是N升和M升)和一罐满的可乐S升,S = N + M,三个容器可以互相倾倒,如果A倒入B,只有两 ...
- BFS(倒水问题) HDU 1495 非常可乐
题目传送门 /* BFS:倒水问题,当C是奇数时无解.一共有六种情况,只要条件符合就入队,我在当该状态vised时写了continue 结果找了半天才发现bug,泪流满面....(网上找份好看的题解都 ...
- 【BFS】HDU 1495
直达–> HDU 1495 非常可乐 相似题联动–>POJ 3414 Pots 题意:中文题,不解释. 思路:三个杯子倒来倒去,最后能让其中两个平分即可.可能性六种.判定的时候注意第三个杯 ...
- HDU 1495 非常可乐(数论,BFS)
非常可乐 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- HDU 1495 非常可乐
http://acm.hust.edu.cn/vjudge/contest/view.action?cid=103711#problem/M /*BFS简单题 链接地址: http://acm.hdu ...
- HDU 1495 非常可乐 BFS 搜索
http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目就不说了, 说说思路! 倒可乐 无非有6种情况: 1. S 向 M 倒 2. S 向 N 倒 3. N ...
- hdu 1495 (搜索) 非常可乐
http://acm.hdu.edu.cn/showproblem.php?pid=1495 搜索模拟出每此倒得情况就好,详情见代码\ (好困啊!!!!1) #include<cstdio> ...
- HDU 1495 非常可乐 bfs 难度:1
http://acm.hdu.edu.cn/showproblem.php?pid=1495 第三个杯子的盛水量可由前两个杯子得到,而前两个杯子状态总数在100*100以内,穷举可实现 #includ ...
随机推荐
- tp框架中的一些疑点知识-6
vim自带一个目录浏览器,使用命令:E就可以调出来,实际上就是浏览器的名字就是"网络读写"netrw vim也自带了 补全功能, 启动键是 "ctrl_N" 或 ...
- SpringBoot 全局统一记录日志
1.记录日志 使用aop来记录controller中的请求返回日志 pom.xml引入: <dependency> <groupId>org.springframework.b ...
- 颠倒的价牌|2013年蓝桥杯A组题解析第四题-fishers
颠倒的价牌 小李的店里专卖其它店中下架的样品电视机,可称为:样品电视专卖店. 其标价都是4位数字(即千元不等). 小李为了标价清晰.方便,使用了预制的类似数码管的标价签,只要用颜色笔涂数字就可以了(参 ...
- Newcoder 华华给月月出题(线筛)题解
题目描述: 华华刚刚帮月月完成了作业.为了展示自己的学习水平之高超,华华还给月月出了一道类似的题: Ans=⊕Ni=1(iNmod(109+7))Ans=⊕i=1N(iNmod(109+7)) ⊕⊕符 ...
- 【系列教程1】Gradle入门系列一:简介
Gradle是一种构建工具,它抛弃了基于XML的构建脚本,取而代之的是采用一种基于Groovy的内部领域特定语言.近期,Gradle获得了极大的关注. 这篇文章是Gradle教程的第一篇,我们有两个目 ...
- p4168 [Violet]蒲公英(分块)
区间众数的重题 和数列分块入门9双倍经验还是挺好的 然后开O2水过 好像有不带log的写法啊 之后在补就是咕咕咕 // luogu-judger-enable-o2 #include <cstd ...
- K8S 安装笔记
1. 准备CentOS7环境 #关闭防火墙 # systemctl disable firewalld # systemctl stop firewalld #安装etcd, kubernetes(会 ...
- React native 之android的图标和启动图片
哎哎呀呀,上篇说到了react native的IOS的图标和启动图片的设置,其实最主要的是尺寸!相应的尺寸设定好了以后就不会报错了! ok~这篇说的是React native的android的图标和启 ...
- C++图形开发相关
1. WxWidgets 2. GTK+ 3. U++ Framework 4. QT
- WebStorm破解方法
http://www.jianshu.com/p/85266fa16639 http://idea.lanyus.com/ webstorm 入门指南 破解方法 1. 下载的WebStorm http ...