非常可乐 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 ...
随机推荐
- 在Linux安装和使用LinuxBrew
简介 LinuxBrew是流行的Mac OS X的一个Linux叉自制包管理器. LinuxBrew是包管理软件,它能从源(在Debian / Ubuntu的如"易/ DEB",并 ...
- python 之 运算符
Python 运算符 Python 运算符 什么是运算符? 本章节主要说明Python的运算符.举个简单的例子 4 +5 = 9 . 例子中,4和5被称为操作数,"+"号为运算 ...
- Docker与.Net项目类型
使用Docker的项目,要求:基础类库与平台无关=>.netCore项目..netStandard项目 公共项目:.netCore项目 入口项目:.netStandard项目 例如:webapi ...
- [转载]哪个版本的gcc才支持c11
转自:https://blog.csdn.net/haluoluo211/article/details/71141093 哪个版本的gcc才支持c11 2017年05月03日 19:25:43 Fi ...
- Entity Framework Core导航属性加载问题
前言 今天下午在开发的时候发现EF Core实体模型中的导航属性为 null,经排查既不是没有加 virtual 关键字,也不是外键关系映射错误. 解决方法 通过查询官网文档,发现,原因在于EF Co ...
- 让你的 Python 代码优雅又地道
示例代码和引用的语录都来自Raymond的演讲.这是我按我的理解整理出来的,希望你们理解起来跟我一样顺畅! 遍历一个范围内的数字 for i in [0, 1, 2, 3, 4, 5]: print ...
- 【Oracle】【问题】
1. java.sql.SQLException: 对只转发结果集的无效操作: last 参考:https://www.cnblogs.com/gaoyuchuanIT/articles/411888 ...
- Codeforces 767D - Cartons of milk
题目链接:http://codeforces.com/contest/767/problem/D D比C水系列. 将商店里面的牛奶按照保质期升序排序(显然优先买保质期久的)考虑二分答案,然后再将整个序 ...
- 单源最短路——Dijkstra模板
算法思想: 类似最小生成树的贪心算法,从起点 v0 每次新拓展一个距离最小的点,再以这个点为中间点,更新起点到其他点的距离. 算法实现: 需要定义两个一维数组:①vis[ i ] 表示是否从源点到顶点 ...
- ones测试用例管理平台
https://ones.ai 团队信息: 公司信息,公司logo付费信息:绑定第三方账户: 成员信息: userid,user_email,激活状态,所属部门组织架构:所属部门: 新建组 团队权钱: ...