http://acm.hdu.edu.cn/showproblem.php?pid=1495

题目就不说了, 说说思路!

倒可乐 无非有6种情况:

1. S 向 M 倒

2. S 向 N 倒

3. N 向 M 倒

4. N 向 S 倒

5. M 向 S 倒

6. M 向 N 倒

根据上述的六种情况来进行模拟, 每次模拟的结果都放进队列里面。

注意: 还要用到标记数组,防止数据重复进入队列导致爆栈。

 #include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<queue>
#include<string.h>
#include<iostream>
using namespace std;
#define maxn 110 struct Node
{
int m;//M瓶子中装的可乐数m
int n;
int s;
int k;//总共倒的次数
};
int M, N, S;
int BFS(Node P);
bool vis[maxn][maxn][maxn];//标记此情况是否有过, 防止重复
int main()
{
Node P;
while(scanf("%d%d%d",&S,&M,&N),M+N+S)
{
int t;
if(M < N)//将M存为最大的
t = M, M = N, N = t;
memset(vis,,sizeof(vis));
P.s = S, P.m = P.n = P.k = ;
int ans = -;
if(S% == )//奇数是没法平分的
ans = BFS(P); if(ans == -)
printf("NO\n");
else
printf("%d\n",ans);
}
return ;
} int BFS(Node P)
{
queue<Node> Q;
Q.push(P);
int x;
while( !Q.empty() )
{
Node Pn;
Pn = Q.front();
Q.pop(); if(Pn.s == S/ && Pn.m == S/ )//当两个瓶子都是S/2则满足
return Pn.k; P.k = Pn.k + ;
/*下面就是倒可乐的过程*/
if(Pn.s < S)
{
x = S - Pn.s; if(Pn.n > x && !vis[S][Pn.n-x][Pn.m])
{
vis[S][Pn.n-x][Pn.m] = ;
P.s = S, P.m = Pn.m, P.n = Pn.n-x;
Q.push(P);
}
else if(Pn.n <= x && !vis[Pn.s+Pn.n][][Pn.m])
{
vis[Pn.s+Pn.n][][Pn.m] = ;
P.s = Pn.s + Pn.n, P.m = Pn.m, P.n = ;
Q.push(P);
} if(Pn.m > x && !vis[S][Pn.n][Pn.m-x])
{
vis[S][Pn.n][Pn.m-x] = ;
P.s = S, P.n = Pn.n, P.m = Pn.m-x;
Q.push(P);
}
else if(Pn.m <= x && !vis[Pn.s+Pn.m][Pn.n][])
{
vis[Pn.s+Pn.m][Pn.n][] = ;
P.s = Pn.s+Pn.m, P.n = Pn.n, P.m = ;
Q.push(P);
}
} if(Pn.n < N)
{
x = N - Pn.n; if(Pn.s > x && !vis[Pn.s-x][N][Pn.m])
{
vis[Pn.s-x][N][Pn.m] = ;
P.s = Pn.s-x, P.n = N, P.m = Pn.m;
Q.push(P);
}
else if(Pn.s <= x && !vis[][Pn.n+Pn.s][Pn.m])
{
vis[][Pn.n+Pn.s][Pn.m] = ;
P.s = , P.n = Pn.n+Pn.s, P.m = Pn.m;
Q.push(P);
} if(Pn.m > x && !vis[Pn.s][N][Pn.m-x])
{
vis[Pn.s][N][Pn.m-x] = ;
P.s = Pn.s, P.n = N, P.m = Pn.m-x;
Q.push(P);
}
else if(Pn.m <= x && !vis[Pn.s][Pn.n+Pn.m][])
{
vis[Pn.s][Pn.n+Pn.m][] = ;
P.s = Pn.s, P.n = Pn.n+Pn.m, P.m = ;
Q.push(P);
}
} if(Pn.m < M)
{
x = M - Pn.m; if(Pn.s > x && !vis[Pn.s-x][Pn.n][M])
{
vis[Pn.s-x][Pn.n][M] = ;
P.s = Pn.s-x, P.n = Pn.n, P.m = M;
Q.push(P);
}
else if(Pn.s <= x && !vis[][Pn.n][Pn.m+Pn.s])
{
vis[][Pn.n][Pn.m+Pn.s] = ;
P.s = , P.n = Pn.n, P.m = Pn.m+Pn.s;
Q.push(P);
} if(Pn.n > x && !vis[Pn.s][Pn.n-x][M])
{
vis[Pn.s][Pn.n-x][M] = ;
P.s = Pn.s, P.n = Pn.n-x, P.m = M;
Q.push(P);
}
else if(Pn.n <= x && !vis[Pn.s][][Pn.m+Pn.n])
{
vis[Pn.s][][Pn.m+Pn.n] = ;
P.s = Pn.s-x, P.n =, P.m = Pn.m+Pn.n;
Q.push(P);
}
}
}
return -;
}

HDU 1495 非常可乐 BFS 搜索的更多相关文章

  1. HDU 1495 非常可乐 BFS搜索

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

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

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

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

    题目大意:输入三个整数 a,b,c.   a : 可乐瓶的容量,b: 甲杯的容量 ,c: 乙杯的容量.问能否用这三个被来实现饮料的平分???如果可以输出倒饮料的次数, 否则输出NO 解题思路: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. Java基础知识强化之集合框架笔记14:List集合存储字符串并遍历

    1. List集合存储学生对象并遍历: 需求:存储字符串并遍历 分析: (1)创建集合对象 (2)创建字符串对象 (3)添加字符串对象到集合中 (4)遍历集合 2. 代码示例: package cn. ...

  2. MAC 环境下 初始化新的mysql root 密码

    mac 环境下初始化mysql的root密码 关掉mysql服务,打开系统设置最后的mysql,然后将mysql先关掉 生成一个文件命名mysql-init,文件中放入:一句话,这句话不同版本不一样, ...

  3. centos mysql 编译安装

    centos mysql 编译安装 1.安装 创建MySQL用户 sudo useradd mysql 下载MySQL的源码包,我们这里使用的时5.5.18 安装依赖 sudo yum -y inst ...

  4. jquery生产和开发的区别

    今天说一下jquery生产和开发的区别,在我们下载jquery的时候,会有两个下载链接,一个是jquery.min.js .迷你版 (生产),另一个是 jquery.js .开发版 .不知道的人可能就 ...

  5. 初识 Angular 体会

    一句话描述:一个前端的类似MVC框架的JS库 刚接触2天,刚一看感觉和asp.net mvc能实现的功能有点重复. 虽然asp.net的表单验证,Razor语法使其在前端开发有较大提升,但要实现比较高 ...

  6. power desinger 学习笔记<八>

    转-PowerDesigner 把Comment复制到name中和把name复制到Comment 在使用PowerDesigner对数据库进行概念模型和物理模型设计时,一般在NAME或Comment中 ...

  7. 330. Patching Array--Avota

    问题描述: Given a sorted positive integer array nums and an integer n, add/patch elements to the array s ...

  8. 初试ubuntu14.4问题集锦2

    好的,我开始继续鼓捣. 想了这么长时间,我想到的是,肯定是compiz设置了unity的什么东西才导致这种问题,绝非什么显卡驱动的事情. 于是二话不说,开机登录,进入tty1,然后apt-get re ...

  9. 使用php实现爬虫程序 套取网站的图片实例

    <?php //去采集a67 图片 网站链接 http://www.xiamov.com/list/1/p.2 你也可以采集其他网站的图片 //创建链接 dedecms--a67 //设置执行不 ...

  10. 用PHP添加购物商品

    <?php session_start(); header ( "Content-type: text/html; charset=UTF-8" ); //设置文件编码格式 ...