HDOJ 1495 非常可乐 【BFS】
非常可乐
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 5954 Accepted Submission(s): 2428
由于每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶可乐。并且一定要喝的和seeyou一样多。但seeyou的手中仅仅有两个杯子。它们的容量各自是N 毫升和M 毫升 可乐的体积为S (S<101)毫升 (正好装满一瓶) ,它们三个之间能够相互倒可乐 (都是没有刻度的。且 S==N+M,101>S>0。N>0,M>0) 。
聪明的ACMER你们说他们能平分吗?假设能请输出倒可乐的最少的次数,假设不能输出"NO"。
7 4 3
4 1 3
0 0 0
NO
3
分析:可以将本题看成一个隐式图,枚举全部的情况直到可以平分,或者枚举完。
代码:
#include <cstdio>
#include <queue> //用到了优先队列
#include <cstring>
#include <algorithm>
const int M = 101;
using namespace std; bool vis[101][101][101]; //标记状态
struct node{
int v[3];
int step;
bool operator < (const node &a) const{
return step > a.step;
}
};
int hal, v[3]; //hal是一半,v数组是每一个杯子的容积 bool match(node a){
int ans = 0;
for(int i = 0; i < 3; ++ i)
if(a.v[i] == hal) ++ans;
if(ans == 2) return 1; //
return 0;
} int bfs(){
memset(vis, 0, sizeof(vis));
node st;
st.v[0] = v[0]; st.v[1] = st.v[2] = 0;
st.step = 0;
priority_queue<node >q;
q.push(st);
vis[v[0]][0][0] = 1;
if(match(st)) return st.step;
while(!q.empty()){
node temp = q.top();
q.pop();
for(int i = 0; i < 3; ++ i){
if(temp.v[i]){ //假设一个杯子有水,就让他往其它两个杯子倒水
for(int j = 1; j < 3; ++ j){
node cur = temp;
int w = (i+j)%3;
if(cur.v[w] < v[w]){ //倒的时候也分是不是满了,假设不满那么还须要推断能不能倒满还是不能倒满
if(cur.v[i] <= (v[w]-cur.v[w])){
cur.v[w] += cur.v[i]; cur.v[i] = 0;
if(match(cur)) return cur.step+1;
}
else {
cur.v[i] -= (v[w]-cur.v[w]);
cur.v[w] = v[w];
if(match(cur)) return cur.step+1;
}
if(!vis[cur.v[0]][cur.v[1]][cur.v[2]]){
vis[cur.v[0]][cur.v[1]][cur.v[2]] = 1;
cur.step++;
q.push(cur);
}
}
}
}
}
}
return -1;
} int main(){
while(scanf("%d%d%d", &v[0], &v[1], &v[2]), v[0]||v[1]||v[2]){
if(v[0]&1){
printf("NO\n");
continue;
}
else {
hal = v[0]/2;
int ans = bfs();
if(ans >= 0) printf("%d\n", ans);
else printf("NO\n");
}
}
return 0;
}
版权声明:本文博主原创文章,博客,未经同意不得转载。
HDOJ 1495 非常可乐 【BFS】的更多相关文章
- hdoj 1495 非常可乐【bfs隐式图】
非常可乐 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- HDU 1495 非常可乐 BFS 搜索
http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目就不说了, 说说思路! 倒可乐 无非有6种情况: 1. S 向 M 倒 2. S 向 N 倒 3. N ...
- (step4.2.5)hdu 1495(非常可乐——BFS)
题目大意:输入三个整数 a,b,c. a : 可乐瓶的容量,b: 甲杯的容量 ,c: 乙杯的容量.问能否用这三个被来实现饮料的平分???如果可以输出倒饮料的次数, 否则输出NO 解题思路:BFS ...
- HDU 1495 非常可乐 BFS搜索
题意:有个为三个杯子(杯子没有刻度),体积为s,n,m,s=m+n, 刚开始只有体积为s的杯子装满可乐,可以互相倒,问你最少的次数使可乐均分,如果没有结果,输出-1; 分析:直接互相倒就完了,BFS模 ...
- HDU 1495 非常可乐 BFS
题目大意:中文题不说了. 题目思路:我有同学用GCD数论写出来的代码很简洁,但是很抱歉,数论蒟蒻,我觉得比赛的时候我没办法推出.如果用BFS的话思路很简单的,就是6方向广搜,只不过稍微麻烦点.具体看代 ...
- HDU 1495 非常可乐 bfs 难度:1
http://acm.hdu.edu.cn/showproblem.php?pid=1495 第三个杯子的盛水量可由前两个杯子得到,而前两个杯子状态总数在100*100以内,穷举可实现 #includ ...
- HDU - 1495 非常可乐 bfs互倒三杯水
非常可乐 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- BFS(倒水问题) HDU 1495 非常可乐
题目传送门 /* BFS:倒水问题,当C是奇数时无解.一共有六种情况,只要条件符合就入队,我在当该状态vised时写了continue 结果找了半天才发现bug,泪流满面....(网上找份好看的题解都 ...
- HDU1495 非常可乐 —— BFS + 模拟
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 非常可乐 Time Limit: 2000/1000 MS (Java/Others) M ...
随机推荐
- Android APN配置
APN概念 APN(Access Point Name),即“接入点名称”,用来标识GPRS的业务种类,目前分为两大类:CMWAP(通过GPRS访问WAP业务).CMNET(除了WAP以外的服务目前都 ...
- docker数据管理2
3. 定义数据卷容器: 只是为了共享数据 docker run -itd -v /data/ --name centeos_testv centos bash /data/ 就是虚拟机内的目录,和宿主 ...
- Linux学习之十六、文件的格式化与相关处理
原文地址:http://vbird.dic.ksu.edu.tw/linux_basic/0330regularex_4.php 文件的格式化与相关处理 接下来让我们来将文件进行一些简单的编排吧!底下 ...
- hdu 5586 Sum(dp+技巧)
Problem Description There )mod10007.After that,the sum of n numbers should be as much as possible.Wh ...
- javascript高级知识分析——上下文
如果函数是一个对象的属性,那么它可以? var katana = { isSharp: true, use: function(){ this.isSharp = !this.isSharp; } } ...
- self
self在对象方法中使用,指代调用当前对象方法的对象.可以利用self->属性名称的方法访问成员变量 self在类方法中使用,其指代的是当前类. 使用总结: self 谁调用当前方法,self就 ...
- JS继承,原型继承,构造函数的继承,非构造函数"的继承
a.原型继承 一.new运算符的缺点 用构造函数生成实例对象,有一个缺点,那就是无法共享属性和方法.比如,在DOG对象的构造函数中,设置一个实例对象的共有属性species. function DOG ...
- SQL Server 备份维护计划
1. 创建维护计划:SSMS -> 管理 -> 维护计划 -> 新建维护计划 2. 添加子计划(备份计划) a) 每30分钟:事务日志备份 每天:差异备份 每周:完整备份 b) ...
- Oracle EBS 如何月结[Z]
概述应付模块的多数业务基于采购和库存的操作,因此应付模块的月结应该在采购模块和库存模块月结后才能关闭会计期.月结步骤在每个会计期末,应付模块的月结应遵循以下流程:1.检查业务是否全部录入;2.检查是否 ...
- 教你如何利用初级C#语言更改银行存款!!!!
您是否对生活现状不满意? 您是否总是感叹工资太少? 您是否经常发现自己相中的物品又降价了然而自己却还是只能望洋兴叹? 没关系!让我来拯救你的钱包! 接下来进入正题: 要想更改自己的银行存款首先得找到一 ...