非常可乐

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 5954    Accepted Submission(s): 2428

Problem Description
大家一定觉的运动以后喝可乐是一件非常满意的事情,可是seeyou却不这么觉得。

由于每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶可乐。并且一定要喝的和seeyou一样多。但seeyou的手中仅仅有两个杯子。它们的容量各自是N 毫升和M 毫升 可乐的体积为S (S<101)毫升 (正好装满一瓶) ,它们三个之间能够相互倒可乐 (都是没有刻度的。且 S==N+M,101>S>0。N>0,M>0) 。

聪明的ACMER你们说他们能平分吗?假设能请输出倒可乐的最少的次数,假设不能输出"NO"。

 
Input
三个整数 : S 可乐的体积 , N 和 M是两个杯子的容量,以"0 0 0"结束。
 
Output
假设能平分的话请输出最少要倒的次数,否则输出"NO"。
 
Sample Input
7 4 3
4 1 3
0 0 0
 
Sample Output
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】的更多相关文章

  1. hdoj 1495 非常可乐【bfs隐式图】

    非常可乐 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  2. HDU 1495 非常可乐 BFS 搜索

    http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目就不说了, 说说思路! 倒可乐 无非有6种情况: 1. S 向 M 倒 2. S 向 N 倒 3. N ...

  3. (step4.2.5)hdu 1495(非常可乐——BFS)

    题目大意:输入三个整数 a,b,c.   a : 可乐瓶的容量,b: 甲杯的容量 ,c: 乙杯的容量.问能否用这三个被来实现饮料的平分???如果可以输出倒饮料的次数, 否则输出NO 解题思路:BFS ...

  4. HDU 1495 非常可乐 BFS搜索

    题意:有个为三个杯子(杯子没有刻度),体积为s,n,m,s=m+n, 刚开始只有体积为s的杯子装满可乐,可以互相倒,问你最少的次数使可乐均分,如果没有结果,输出-1; 分析:直接互相倒就完了,BFS模 ...

  5. HDU 1495 非常可乐 BFS

    题目大意:中文题不说了. 题目思路:我有同学用GCD数论写出来的代码很简洁,但是很抱歉,数论蒟蒻,我觉得比赛的时候我没办法推出.如果用BFS的话思路很简单的,就是6方向广搜,只不过稍微麻烦点.具体看代 ...

  6. HDU 1495 非常可乐 bfs 难度:1

    http://acm.hdu.edu.cn/showproblem.php?pid=1495 第三个杯子的盛水量可由前两个杯子得到,而前两个杯子状态总数在100*100以内,穷举可实现 #includ ...

  7. HDU - 1495 非常可乐 bfs互倒三杯水

    非常可乐 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  8. BFS(倒水问题) HDU 1495 非常可乐

    题目传送门 /* BFS:倒水问题,当C是奇数时无解.一共有六种情况,只要条件符合就入队,我在当该状态vised时写了continue 结果找了半天才发现bug,泪流满面....(网上找份好看的题解都 ...

  9. HDU1495 非常可乐 —— BFS + 模拟

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 非常可乐 Time Limit: 2000/1000 MS (Java/Others)    M ...

随机推荐

  1. .net c# 正则表达式 平衡组/递归匹配

    原文 http://www.cnblogs.com/qiantuwuliang/archive/2011/06/11/2078482.html 平衡组/递归匹配 这里介绍的平衡组语法是由.Net Fr ...

  2. tracker-store and tracker-miner-fs eating up my CPU on every startup

    Tracker is a synergy of technologies that are designed to provide a highly sophisticated, innovative ...

  3. DLL中传递STL参数,vector对象作为dll参数传递等问题(转)

    STL跨平台调用会出现很多异常,你可以试试. STL使用模板生成,当我们使用模板的时候,每一个EXE,和DLL都在编译器产生了自己的代码,导致模板所使用的静态成员不同步,所以出现数据传递的各种问题,下 ...

  4. Kruskal-Wallis Test and Friedman test

  5. 深入理解java String 对象的不可变性

    下面我们通过一组图表来解释Java字符串的不可变性 1.声明一个String对象 String s = "abcd"; 2.将一个String变量赋值给另一个String变量 St ...

  6. Unity CCTween UGUI 动画插件

    在这简单的介绍一下 CCTween 动画插件的使用 因为GIF 制作软件不太好(网上随便下载的)所以导致效果不太好,有时间我重新制作一下 这是一下简单的效果 下面介绍怎么使用 首先 先下载 CCTwe ...

  7. break与continue

    1.break与continue.这两个关键字一般放在循环的花括号里面使用.break——结束整个循环.continue——结束本次循环,进入下次循环. break的案例: int i = 1; fo ...

  8. SPRING 配置文件和类名

    今天写项目碰到一个很奇怪的问题,无论怎么改,还是一直包空指针 最终的问题出现在spring配置文件

  9. PHP比较全的友好的时间显示,比如‘刚刚’,'几秒前'等

    分享一个php友好的比较完成的时间格式化函数,包括‘刚刚’,'几秒之前',‘几分钟前’,'几小时前',几天前,几周前,几个月前等.调用方式很简单,是从ThinkSNS 里面拿出来的. /** * 友好 ...

  10. js设置元素readonly属性注意事项

    注意大小写,应该为:obj.readOnly = true;