(step4.2.5)hdu 1495(非常可乐——BFS)
题目大意:输入三个整数 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)的更多相关文章
- HDU 1495 非常可乐 BFS 搜索
http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目就不说了, 说说思路! 倒可乐 无非有6种情况: 1. S 向 M 倒 2. S 向 N 倒 3. N ...
- HDU 1495 非常可乐 bfs 难度:1
http://acm.hdu.edu.cn/showproblem.php?pid=1495 第三个杯子的盛水量可由前两个杯子得到,而前两个杯子状态总数在100*100以内,穷举可实现 #includ ...
- HDU 1495 非常可乐 BFS搜索
题意:有个为三个杯子(杯子没有刻度),体积为s,n,m,s=m+n, 刚开始只有体积为s的杯子装满可乐,可以互相倒,问你最少的次数使可乐均分,如果没有结果,输出-1; 分析:直接互相倒就完了,BFS模 ...
- HDU 1495 非常可乐 BFS
题目大意:中文题不说了. 题目思路:我有同学用GCD数论写出来的代码很简洁,但是很抱歉,数论蒟蒻,我觉得比赛的时候我没办法推出.如果用BFS的话思路很简单的,就是6方向广搜,只不过稍微麻烦点.具体看代 ...
- 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,泪流满面....(网上找份好看的题解都 ...
- HDU 1495 非常可乐(数论,BFS)
非常可乐 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- 非常可乐---hdu 1495(BFS)
http://acm.hdu.edu.cn/showproblem.php?pid=1495 题意: 有3个杯子a b c:a=b+c:然后刚开始时只有a是满的,其它为空的,然后a b c三个之间互相 ...
- HDU 1495 非常可乐(BFS倒水问题)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目大意:只有两个杯子,它们的容量分别是N 毫升和M 毫升 可乐的体积为S (S<101) ...
随机推荐
- [转载]Sublime Text 3 搭建 React.js 开发环境
[转载]Sublime Text 3 搭建 React.js 开发环境 Sublime有很强的自定义功能,插件库很庞大,针对新语言插件更新很快,配合使用可以快速搭建适配语言的开发环境. 1. babe ...
- 项目开发-->身份认证及用户登录模块
1.首先明确的两个问题 如何判断当前申请是由一个已登录用户发起的?如果Request.IsAuthenticated为true,则表示是一个已登录用户. 如何获取当前登录用户的登录名?如果是一个已登录 ...
- C# Redis
概念 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,和Memcached类似,它支持存储的value类型相对更多,包括string( ...
- SPOJ-SQRBR Square Brackets
原题传送:http://www.spoj.pl/problems/SQRBR 动态规划. 设f[i][j]表示前i个位置在合法情况下缺少j个右括号的方案数. 转移方程为: f[i][j] = f[i- ...
- BZOJ2039 [2009国家集训队]employ人员雇佣
AC通道:http://www.lydsy.com/JudgeOnline/problem.php?id=2039 鉴于一开始看题如果不仔细是看不懂题目的,还是说一下题目大意 [题目大意]:给定n个人 ...
- bzoj 1041 圆上的整点 分类: Brush Mode 2014-11-11 20:15 80人阅读 评论(0) 收藏
这里先只考虑x,y都大于0的情况 如果x^2+y^2=r^2,则(r-x)(r+x)=y*y 令d=gcd(r-x,r+x),r-x=d*u^2,r+x=d*v^2,显然有gcd(u,v)=1且u&l ...
- Codeforces Round #231 (Div2) 迟到的解题报告
题目A: 给一个火柴等式,可以从左边移动一根到右边,也可以从右边移到左边,但是不能移动“+”,”=“的火柴, 而且加法里面的数都要大于0(很重要的条件),基本上注意到这点的都过了,没注意的都被HACK ...
- Python:异常处理
Python 是面向对象的语言,所以程序抛出的异常也是类. 一.常见的异常类 NameError:尝试访问一个没有申明的变量 ZeroDivisionError:除数为 0 SyntaxError:语 ...
- hbase表结构设计
非常好的一个ppt HBase Schema design: http://www.slideshare.net/cloudera/5-h-base-schemahbasecon2012
- KMP高质量代码实现详解
KMP算法 对于KMP算法我分为两个部分说明,第一部分是算法部分,介绍KMP算法的算法思想:第二部分是实现部分,介绍一种厉害的实现代码以及代码注释.当然了由于本文主要介绍怎么实现故而先分析实现,对KM ...