HDU 1495 非常可乐 BFS 搜索
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 搜索的更多相关文章
- HDU 1495 非常可乐 BFS搜索
题意:有个为三个杯子(杯子没有刻度),体积为s,n,m,s=m+n, 刚开始只有体积为s的杯子装满可乐,可以互相倒,问你最少的次数使可乐均分,如果没有结果,输出-1; 分析:直接互相倒就完了,BFS模 ...
- HDU 1495 非常可乐 bfs 难度:1
http://acm.hdu.edu.cn/showproblem.php?pid=1495 第三个杯子的盛水量可由前两个杯子得到,而前两个杯子状态总数在100*100以内,穷举可实现 #includ ...
- (step4.2.5)hdu 1495(非常可乐——BFS)
题目大意:输入三个整数 a,b,c. a : 可乐瓶的容量,b: 甲杯的容量 ,c: 乙杯的容量.问能否用这三个被来实现饮料的平分???如果可以输出倒饮料的次数, 否则输出NO 解题思路: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) ...
随机推荐
- display:table- cell属性的练习
display:table- cell属性指让标签元素以表格单元格的形式呈现,类似于td标签.目前IE8+以及其他现代浏览器都是支持此属性的,但是IE6/7只能对你说 sorry了,这一事实也是大大制 ...
- 原生JS与jQuery文档加载完毕的写法
HTML是有执行顺序的,默认是自上而下执行.所以当我们的js代码在html代码下边的时候,可以正常执行,而当我们的js代码在html代码上边的时候,可以就无法正常执行了,这时,我们需要在文档加载完毕的 ...
- C#语法糖之开篇
本人虽然大学不是学的计算机但是对于IT行业的热爱,依然决然进军IT行业了,自从踏进这个行业到现在也已经3年多了,从去年开发通过网上 了解博客园后深深的爱上这儿了,这里有很多牛人,通过拜读他们的代码,让 ...
- Android开发---支付宝功能接口(支付功能)(转载!)
最近在做一个关于购物商城的项目,项目里面付款这块我选的是调用支付宝的接口,因为用的人比较多. 在网上搜索了以下,有很多这方面的教程,但大部分教程过于陈旧,而且描述的过于简单.而且支付宝提供的接口一直在 ...
- HDU 3359 Kind of a Blur(高斯消元)
题意: H * W (W,H <= 10) 的矩阵A的某个元素A[i][j],从它出发到其他点的曼哈顿距离小于等于D的所有值的和S[i][j]除上可达点的数目,构成了矩阵B.给定矩阵B,求矩阵A ...
- QQ弹窗代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- Apache与php的整合(经典版),花了一天去配置成功经验
1.首先在官方下载php-7.0.7-Win32-VC14-x64.zip和httpd-2.4.20-win64-VC14.zip,也可以下载镜像版的apache:apache_2.4.4-x64-o ...
- impress.js学习总结
impress.js是一个很有趣的用来替代PPT的展示用的js工具,它的灵感来自prezi 如果你要学习使用它,这里有很好的演示模板 使用它的第一步,下载 impress.js,引入到你的代码里,并执 ...
- WWDC2014之App Extensions学习笔记
一.关于App Extensions extension是iOS8新开放的一种对几个固定系统区域的扩展机制,它可以在一定程度上弥补iOS的沙盒机制对应用间通信的限制. extension的出现,为用户 ...
- iscc2016-basic-find-to-me
额 第一题就暴力搜索了 已知仿射加密变换为c=(11m+8)mod26,试对密文sjoyuxzr解密 #include <stdio.h> int main(void) { int m,c ...