非常可乐 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 ...
随机推荐
- Miller_Rabin整理笔记
目录 问题 别的 正事 代码 问题 一个数到底是不是素数 别的 首先列一下我们可以求素数的东西 根号暴力求 \(O(nloglogn)\)的埃氏筛 \(O(n)\)的欧拉筛 还有我们要学习的Mille ...
- sql -- 移除数据中的换行符和回车符
https://blog.csdn.net/jcx5083761/article/details/40185795 --移除回车符 update master_location SET street_ ...
- A successful Git branching model——经典篇
A successful Git branching model In this post I present the development model that I’ve introduced f ...
- Linux命令2——b
badblocks:检查磁盘设备中损坏的区块 -b:指定磁盘的区块大小,单位:字节 -c:一次检查几个区块 -i:由文件总读取已知的损坏区块,检查时会忽略这些区块 -o:检查的结果写入指定的输出文件. ...
- Hyper-v虚拟机
Hyper-V1:创建和管理虚拟机 Hyper-V2:向VM增加虚拟硬盘 Hyper-V3:虚拟机的配置 使用Hyper-V创建虚拟机 Hyper-v 安装CentOS 7 (其他虚拟机一样参考)
- Python学习 day04打卡
今天学习的主要内容: 一,列表 1,列表的介绍 列表是python的基础数据类型之一,其他编程语音也有类似的数据类型.例如:JS 中的数组Java中的数组等等. 它是以[]括起来,每个元素用',隔开而 ...
- hiho #1196 : 高斯消元·二
#1196 : 高斯消元·二 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在上一回中,小Hi和小Ho趁着便利店打折,买了一大堆零食.当他们结账后,看到便利店门口还有其 ...
- RESTful 个人理解总结
一.什么是RESTful 面向资源 简单的说:RESTful是一种架构的规范与约束.原则,符合这种规范的架构就是RESTful架构. 先看REST是什么意思,英文Representational ...
- java根据地址获取百度API经纬度
java根据地址获取百度API经纬度(详细文档) public void getLarLng(String address) throws Exception { String ak = " ...
- RedHat(Linux)下安装Python3步骤
1. 下载解压.$ wget https://www.python.org/ftp/python/3.4.1/Python-3.4.1.tgz$ tar zxvf Python-3.4.1.tgz 2 ...