题目链接

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

思路

首先 如果可乐的体积 是奇数 那么是无解的

然后 如果能够得到两杯 都是一般容量的可乐 那么一定是装在 原来那个可乐被子 以及 大一点的杯子当中

要找最少步骤 容易知道 用 BFS

每次转移的状态有

s -> n s -> m n -> s n -> m m -> s m -> n

用 vis 标记 状态

最后如果满足条件 就return

当然 即使可乐体积是偶数 也有可能 是没有办法满足条件的 也就是要设置一个哨兵

AC代码

#include <cstdio>
#include <cstring>
#include <ctype.h>
#include <cstdlib>
#include <cmath>
#include <climits>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <deque>
#include <vector>
#include <queue>
#include <string>
#include <map>
#include <stack>
#include <set>
#include <numeric>
#include <sstream>
#include <iomanip>
#include <limits> #define CLR(a) memset(a, 0, sizeof(a))
#define pb push_back using namespace std;
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
typedef pair <int, int> pii;
typedef pair <ll, ll> pll;
typedef pair<string, int> psi;
typedef pair<string, string> pss; const double PI = acos(-1);
const double E = exp(1);
const double eps = 1e-30; const int INF = 0x3f3f3f3f;
const int maxn = 1e2 + 5;
const int MOD = 1e9 + 7; struct node
{
int s, n, m, t;
}; int s, n, m; int vis[maxn][maxn]; int bfs()
{
queue <node> q;
CLR(vis);
node temp;
temp.s = s;
temp.n = 0;
temp.m = 0;
temp.t = 0;
vis[n][m] = 1;
q.push(temp);
while (!q.empty())
{
node u = q.front(), v;
q.pop();
if (u.n == s / 2 && u.s == s / 2)
return u.t;
if (u.s && u.n != n) // s -> n
{
int c = n - u.n;
if (u.s >= c)
{
v.s = u.s - c;
v.n = n;
}
else
{
v.s = 0;
v.n = u.n + u.s;
}
v.m = u.m;
if (vis[v.n][v.m] == 0)
{
v.t = u.t + 1;
q.push(v);
vis[v.n][v.m] = 1;
}
}
if (u.s && u.m != m) // s -> m
{
int c = m - u.m;
if (u.s >= c)
{
v.s = u.s - c;
v.m = m;
}
else
{
v.s = 0;
v.m = u.m + u.s;
}
v.n = u.n;
if (vis[v.n][v.m] == 0)
{
v.t = u.t + 1;
q.push(v);
vis[v.n][v.m] = 1;
}
}
if (u.n && u.s != s) // n -> s
{
int c = s - u.s;
if (u.n >= c)
{
v.n = u.n - c;
v.s = s;
}
else
{
v.n = 0;
v.s = u.s + u.n;
}
v.m = u.m;
if (vis[v.n][v.m] == 0)
{
v.t = u.t + 1;
q.push(v);
vis[v.n][v.m] = 1;
}
}
if (u.n && u.m != m) // n -> m
{
int c = m - u.m;
if (u.n >= c)
{
v.n = u.n - c;
v.m = m;
}
else
{
v.n = 0;
v.m = u.m + u.n;
}
v.s = u.s;
if (vis[v.n][v.m] == 0)
{
v.t = u.t + 1;
q.push(v);
vis[v.n][v.m] = 1;
}
}
if (u.m && u.s != s) // m -> s
{
int c = s - u.s;
if (u.m >= c)
{
v.m = u.m - c;
v.s = s;
}
else
{
v.m = 0;
v.s = u.s + u.m;
}
v.n = u.n;
if (vis[v.n][v.m] == 0)
{
v.t = u.t + 1;
q.push(v);
vis[v.n][v.m] = 1;
}
}
if (u.m && u.n != n) // m -> n
{
int c = n - u.n;
if (u.m >= c)
{
v.m = u.m - c;
v.n = n;
}
else
{
v.m = 0;
v.n = u.n + u.m;
}
v.s = u.s;
if (vis[v.n][v.m] == 0)
{
v.t = u.t + 1;
q.push(v);
vis[v.n][v.m] = 1;
}
}
}
return 0;
} int main()
{
while (scanf("%d%d%d", &s, &n, &m) && (s || n || m))
{
if (s & 1)
puts("NO");
else
{
if (n < m)
swap(n, m);
int ans = bfs();
if (ans)
cout << ans << endl;
else
puts("NO");
}
}
}

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. (step4.2.5)hdu 1495(非常可乐——BFS)

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

  4. HDU 1495 非常可乐 BFS搜索

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

  5. HDU 1495 非常可乐 BFS

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

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. Weblogic多数据源(Multi Data Sources)应用实践

    原创 2012年03月29日 10:55:28 标签: weblogic / 数据库 / 负载均衡 / 数据中心 / jdbc / 应用服务器   大型系统在进行数据库部署时,常常会分为主数据应用中心 ...

  2. centos7的时间同步机制:chrony使用

    配置时间同步方法如下: 1.安装chrony时间同步服务(系统默认安装) #yum install chrony 可以先查询一下是否有安装: [root@localhost etc]# rpm -qa ...

  3. Android解析Json数据之Gson解析

    Gson是谷歌官方提供的解析json数据的工具类.json数据的解析能够使用JSONObject和JSONArray配合使用解析数据,可是这样的原始的方法对于小数据的解析还是有作用的,可是陪到了复杂数 ...

  4. 在Delphi中应用AOP实现日志功能

    AOP现在很火,网上有这许多支持AOP的框架,对于Delphi来说同样也有MeAOP.不过觉得这些框架太复杂了. 现在有一个系统,基本上都快结束了,整体上当然是没有采用什么AOP的框架.对于这样的系统 ...

  5. 新学到的linux命令

    whatis xxx whatis ls 会返回一个ls的简要说明,可以简单的告诉你该命令的作用,不用man去看一大堆没啥用的英文 HISTTIMEFORMAT="%d/%m/%y %T & ...

  6. poj1691--Painting A Board(拓扑+dfs)

    题目链接:点击打开链接 题目大意:一个矩形由n个小矩形组成,如今要给小矩形染色,可是颜料会向下滑,为了防止弄乱颜料,所以要先染上面的矩形,后然染以下的矩形.每一次改变颜色都要用一个新的刷子.问最小用多 ...

  7. [LeetCode] Decode Ways 解码方法个数、动态规划

    A message containing letters from A-Z is being encoded to numbers using the following mapping: 'A' - ...

  8. 学写jQuery插件开发方法

    jQuery如此流行,各式各样的jQuery插件也是满天飞.你有没有想过把自己的一些常用的JS功能也写成jQuery插件呢?如果你的答案是肯定的,那么来吧!和我一起学写jQuery插件吧!   很多公 ...

  9. Source Insight 4.0 破解和使用

    参考出处: https://blog.csdn.net/u011604775/article/details/81698062 https://blog.csdn.net/user11223344ab ...

  10. 1. WPF学习之概述

    <深入浅出WPF> 前言: C#专业的朋友推荐的WPF入门书籍<深入浅出WPF>,没学过的朋友从今天开始和我一起开启WPF学习之旅吧! 什么是WPF? WPF 是windows ...