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

否则输出NO

解题思路:BFS

1)本题的考点其实在于将标记数组由二维数组变为三维数组。遍历状态由使用for()循环变为手动枚举,一个一个的if()

代码如下:

/*
* 1495_2.cpp
*
* Created on: 2013年8月16日
* Author: Administrator
*/ #include <iostream>
#include <queue> using namespace std;
const int maxn = 102;
bool visited[maxn][maxn][maxn]; int a, b, c;
struct State {
int a;
int b;
int c;
int v;
}; bool checkState(State st) {
if (!visited[st.a][st.b][st.c]) {
return true;
} return false;
} void bfs() {
queue<State> q;
State st, now, next; st.a = a;
st.b = 0;
st.c = 0;
st.v = 0;
q.push(st);
memset(visited,0,sizeof(visited) );
visited[st.a][st.b][st.c] = 1;
while (!q.empty()) {
now = q.front(); //有2个等于a/2就结束
if ((now.a == a / 2 && now.b == a / 2)
|| (now.a == a / 2 && now.c == a / 2)
|| (now.c == a / 2 && now.b == a / 2)) {
printf("%d\n", now.v);
return ;
} /**
* 若a杯中的饮料的体积不为0,
* 则枚举出将a杯中的饮料倒到其他杯中....
*/
if (now.a != 0) {
/**
* 关键举得理解:now.a > b - now.b
* now.a : now状态下a杯中的饮料的体积
* b : b杯的体积
* now.b :now状态下b杯中的饮料的体积
*
*/
if (now.a > b - now.b) {//now.a > b - now.b。且倒不完
next.a = now.a - (b - now.b);
next.b = b;
next.c = now.c;
next.v = now.v + 1;
} else {//倒完了
next.a = 0;
next.b = now.b + now.a;
next.c = now.c;
next.v = now.v + 1;
} if (checkState(next)) {
q.push(next);
visited[next.a][next.b][next.c] = 1;
} if (now.a > c - now.c) {
next.a = now.a - (c - now.c);
next.b = now.b;
next.c = c;
next.v = now.v + 1;
} else {
next.a = 0;
next.b = now.b;
next.c = now.c + now.a;
next.v = now.v + 1;
} if (checkState(next)) {
q.push(next);
visited[next.a][next.b][next.c] = 1;
}
} if (now.b != 0) {
if (now.b > a - now.a) {
next.a = a;
next.b = now.b - (a - now.a);
next.c = now.c;
next.v = now.v + 1;
} else {
next.a = now.a + now.b;
next.b = 0;
next.c = now.c;
next.v = now.v + 1;
} if (checkState(next)) {
q.push(next);
visited[next.a][next.b][next.c] = 1;
} if (now.b > c - now.c) {
next.a = now.a ;
next.b = now.b - (c - now.c);
next.c = c;
next.v = now.v + 1;
} else {
next.a = now.a;
next.b = 0;
next.c = now.c + now.b;
next.v = now.v + 1;
} if (checkState(next)) {
q.push(next);
visited[next.a][next.b][next.c] = 1;
}
} if (now.c != 0) {
if (now.c > b - now.b) {
next.a = now.a ;
next.b = b;
next.c = now.c - (b - now.b);
next.v = now.v + 1;
} else {
next.a = now.a;
next.b = now.b + now.c;
next.c = 0;
next.v = now.v + 1;
} if (checkState(next)) {
q.push(next);
visited[next.a][next.b][next.c] = 1;
} if (now.c > a - now.a) {
next.a = a;
next.b = now.b;
next.c = now.c - (a - now.a);
next.v = now.v + 1;
} else {
next.a = now.a + now.c;
next.b = now.b;
next.c = 0;
next.v = now.v + 1;
} if (checkState(next)) {
q.push(next);
visited[next.a][next.b][next.c] = 1;
}
}
q.pop();
} printf("NO\n");
}
int main() { while(scanf("%d%d%d",&a,&b,&c)!=EOF,a+b+c){
if(a%2 == 1){
printf("NO\n");
}else{
bfs();
}
}
}

(step4.2.5)hdu 1495(非常可乐——BFS)的更多相关文章

  1. HDU 1495 非常可乐 BFS 搜索

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

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

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

  3. HDU 1495 非常可乐 BFS搜索

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

  4. HDU 1495 非常可乐 BFS

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

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

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

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

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

  7. HDU 1495 非常可乐(数论,BFS)

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

  8. 非常可乐---hdu 1495(BFS)

    http://acm.hdu.edu.cn/showproblem.php?pid=1495 题意: 有3个杯子a b c:a=b+c:然后刚开始时只有a是满的,其它为空的,然后a b c三个之间互相 ...

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

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目大意:只有两个杯子,它们的容量分别是N 毫升和M 毫升 可乐的体积为S (S<101) ...

随机推荐

  1. Poj 1904 King's Quest 强连通分量

    题目链接: http://poj.org/problem?id=1904 题意: 有n个王子和n个公主,王子只能娶自己心仪的公主(一个王子可能会有多个心仪的公主),现已给出一个完美匹配,问每个王子都可 ...

  2. Eclipse : cannot open output file(c++)

    之前电脑卡的时候 强制关闭Eclipse,结果打开再次运行的时候却不能输出了:找了网上的原因,是之前那个进程还未关闭 开发环境  Eclipse  for C/C++  &  MinGW Er ...

  3. hdu 2426 Interesting Housing Problem 最大权匹配KM算法

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2426 For any school, it is hard to find a feasible ac ...

  4. 【BZOJ】【3007】拯救小云公主

    思路题 我的naive的做法是二分答案+判定是否有路径可走……但是没有正确理解[走的方向任意]这句话…… 其实就是说想咋走咋走= =360°无死角乱走…… 所以其实是个平面上的问题…… 我们可以换个方 ...

  5. 【BZOJ】【1045/1465】【HAOI2008】糖果传递

    思路题/神奇的转化…… orz hzwer 或许这个思路可以从单行而非环形的递推中找到?(单行的时候,从左往右直接递推即可…… 感觉好神奇>_<脑残患者想不出…… P.S.话说在$n\le ...

  6. 在线最优化求解(Online Optimization)之五:FTRL

    在线最优化求解(Online Optimization)之五:FTRL 在上一篇博文中中我们从原理上定性比较了L1-FOBOS和L1-RDA在稀疏性上的表现.有实验证明,L1-FOBOS这一类基于梯度 ...

  7. 如何做到尽可能不使用庞大的jQuery

    jQuery 是现在最流行的 JavaScript 工具库. 据统计,目前全世界 57.3% 的网站使用它.也就是说,10 个网站里面,有 6 个使用 jQuery.如果只考察使用工具库的网站,这个比 ...

  8. 总结 | 如何测试你自己的 RubyGem

    如何测试一个Gem gem 开发完了,想要给别人用,那就需要测试啊,测试一个 gem 其实很简单,这里我们用 minitest 为例, rspec 也一样适用.先来看看我们当前这个 gem 的目录结构 ...

  9. Javascript里的那些距离们

    1.有滚动条的控件的距离: scrollTop和scrollLeft:分别指有滚动条的容器控件的滚动条的top和left:页面滚动条的通用取法:document.body.scrollTop(FF\C ...

  10. hdu 1250 Hat's Fibonacci(java,简单,大数)

    题目 java做大数的题,真的是神器,来一道,秒一道~~~ import java.io.*; import java.util.*; import java.math.*; public class ...