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 倒

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

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

  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. #include<math.h>
  4. #include<queue>
  5. #include<string.h>
  6. #include<iostream>
  7. using namespace std;
  8. #define maxn 110
  9.  
  10. struct Node
  11. {
  12. int m;//M瓶子中装的可乐数m
  13. int n;
  14. int s;
  15. int k;//总共倒的次数
  16. };
  17. int M, N, S;
  18. int BFS(Node P);
  19. bool vis[maxn][maxn][maxn];//标记此情况是否有过, 防止重复
  20. int main()
  21. {
  22. Node P;
  23. while(scanf("%d%d%d",&S,&M,&N),M+N+S)
  24. {
  25. int t;
  26. if(M < N)//将M存为最大的
  27. t = M, M = N, N = t;
  28. memset(vis,,sizeof(vis));
  29. P.s = S, P.m = P.n = P.k = ;
  30. int ans = -;
  31. if(S% == )//奇数是没法平分的
  32. ans = BFS(P);
  33.  
  34. if(ans == -)
  35. printf("NO\n");
  36. else
  37. printf("%d\n",ans);
  38. }
  39. return ;
  40. }
  41.  
  42. int BFS(Node P)
  43. {
  44. queue<Node> Q;
  45. Q.push(P);
  46. int x;
  47. while( !Q.empty() )
  48. {
  49. Node Pn;
  50. Pn = Q.front();
  51. Q.pop();
  52.  
  53. if(Pn.s == S/ && Pn.m == S/ )//当两个瓶子都是S/2则满足
  54. return Pn.k;
  55.  
  56. P.k = Pn.k + ;
  57. /*下面就是倒可乐的过程*/
  58. if(Pn.s < S)
  59. {
  60. x = S - Pn.s;
  61.  
  62. if(Pn.n > x && !vis[S][Pn.n-x][Pn.m])
  63. {
  64. vis[S][Pn.n-x][Pn.m] = ;
  65. P.s = S, P.m = Pn.m, P.n = Pn.n-x;
  66. Q.push(P);
  67. }
  68. else if(Pn.n <= x && !vis[Pn.s+Pn.n][][Pn.m])
  69. {
  70. vis[Pn.s+Pn.n][][Pn.m] = ;
  71. P.s = Pn.s + Pn.n, P.m = Pn.m, P.n = ;
  72. Q.push(P);
  73. }
  74.  
  75. if(Pn.m > x && !vis[S][Pn.n][Pn.m-x])
  76. {
  77. vis[S][Pn.n][Pn.m-x] = ;
  78. P.s = S, P.n = Pn.n, P.m = Pn.m-x;
  79. Q.push(P);
  80. }
  81. else if(Pn.m <= x && !vis[Pn.s+Pn.m][Pn.n][])
  82. {
  83. vis[Pn.s+Pn.m][Pn.n][] = ;
  84. P.s = Pn.s+Pn.m, P.n = Pn.n, P.m = ;
  85. Q.push(P);
  86. }
  87. }
  88.  
  89. if(Pn.n < N)
  90. {
  91. x = N - Pn.n;
  92.  
  93. if(Pn.s > x && !vis[Pn.s-x][N][Pn.m])
  94. {
  95. vis[Pn.s-x][N][Pn.m] = ;
  96. P.s = Pn.s-x, P.n = N, P.m = Pn.m;
  97. Q.push(P);
  98. }
  99. else if(Pn.s <= x && !vis[][Pn.n+Pn.s][Pn.m])
  100. {
  101. vis[][Pn.n+Pn.s][Pn.m] = ;
  102. P.s = , P.n = Pn.n+Pn.s, P.m = Pn.m;
  103. Q.push(P);
  104. }
  105.  
  106. if(Pn.m > x && !vis[Pn.s][N][Pn.m-x])
  107. {
  108. vis[Pn.s][N][Pn.m-x] = ;
  109. P.s = Pn.s, P.n = N, P.m = Pn.m-x;
  110. Q.push(P);
  111. }
  112. else if(Pn.m <= x && !vis[Pn.s][Pn.n+Pn.m][])
  113. {
  114. vis[Pn.s][Pn.n+Pn.m][] = ;
  115. P.s = Pn.s, P.n = Pn.n+Pn.m, P.m = ;
  116. Q.push(P);
  117. }
  118. }
  119.  
  120. if(Pn.m < M)
  121. {
  122. x = M - Pn.m;
  123.  
  124. if(Pn.s > x && !vis[Pn.s-x][Pn.n][M])
  125. {
  126. vis[Pn.s-x][Pn.n][M] = ;
  127. P.s = Pn.s-x, P.n = Pn.n, P.m = M;
  128. Q.push(P);
  129. }
  130. else if(Pn.s <= x && !vis[][Pn.n][Pn.m+Pn.s])
  131. {
  132. vis[][Pn.n][Pn.m+Pn.s] = ;
  133. P.s = , P.n = Pn.n, P.m = Pn.m+Pn.s;
  134. Q.push(P);
  135. }
  136.  
  137. if(Pn.n > x && !vis[Pn.s][Pn.n-x][M])
  138. {
  139. vis[Pn.s][Pn.n-x][M] = ;
  140. P.s = Pn.s, P.n = Pn.n-x, P.m = M;
  141. Q.push(P);
  142. }
  143. else if(Pn.n <= x && !vis[Pn.s][][Pn.m+Pn.n])
  144. {
  145. vis[Pn.s][][Pn.m+Pn.n] = ;
  146. P.s = Pn.s-x, P.n =, P.m = Pn.m+Pn.n;
  147. Q.push(P);
  148. }
  149. }
  150. }
  151. return -;
  152. }

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. display:table- cell属性的练习

    display:table- cell属性指让标签元素以表格单元格的形式呈现,类似于td标签.目前IE8+以及其他现代浏览器都是支持此属性的,但是IE6/7只能对你说 sorry了,这一事实也是大大制 ...

  2. 原生JS与jQuery文档加载完毕的写法

    HTML是有执行顺序的,默认是自上而下执行.所以当我们的js代码在html代码下边的时候,可以正常执行,而当我们的js代码在html代码上边的时候,可以就无法正常执行了,这时,我们需要在文档加载完毕的 ...

  3. C#语法糖之开篇

    本人虽然大学不是学的计算机但是对于IT行业的热爱,依然决然进军IT行业了,自从踏进这个行业到现在也已经3年多了,从去年开发通过网上 了解博客园后深深的爱上这儿了,这里有很多牛人,通过拜读他们的代码,让 ...

  4. Android开发---支付宝功能接口(支付功能)(转载!)

    最近在做一个关于购物商城的项目,项目里面付款这块我选的是调用支付宝的接口,因为用的人比较多. 在网上搜索了以下,有很多这方面的教程,但大部分教程过于陈旧,而且描述的过于简单.而且支付宝提供的接口一直在 ...

  5. HDU 3359 Kind of a Blur(高斯消元)

    题意: H * W (W,H <= 10) 的矩阵A的某个元素A[i][j],从它出发到其他点的曼哈顿距离小于等于D的所有值的和S[i][j]除上可达点的数目,构成了矩阵B.给定矩阵B,求矩阵A ...

  6. QQ弹窗代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. 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 ...

  8. impress.js学习总结

    impress.js是一个很有趣的用来替代PPT的展示用的js工具,它的灵感来自prezi 如果你要学习使用它,这里有很好的演示模板 使用它的第一步,下载 impress.js,引入到你的代码里,并执 ...

  9. WWDC2014之App Extensions学习笔记

    一.关于App Extensions extension是iOS8新开放的一种对几个固定系统区域的扩展机制,它可以在一定程度上弥补iOS的沙盒机制对应用间通信的限制. extension的出现,为用户 ...

  10. iscc2016-basic-find-to-me

    额 第一题就暴力搜索了 已知仿射加密变换为c=(11m+8)mod26,试对密文sjoyuxzr解密 #include <stdio.h> int main(void) { int m,c ...