题目描述:

大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为。因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶可乐,而且一定要喝的和seeyou一样多。但seeyou的手中只有两个杯子,它们的容量分别是N 毫升和M 毫升 可乐的体积为S (S<101)毫升(正好装满一瓶) ,它们三个之间可以相互倒可乐 (都是没有刻度的,且 S==N+M,101>S>0,N>0,M>0) 。聪明的ACMER你们说他们能平分吗?如果能请输出倒可乐的最少的次数,如果不能输出"NO"。

输入:

三个整数 : S 可乐的体积 , N 和 M是两个杯子的容量,以"0 0 0"结束。

输出:

如果能平分的话请输出最少要倒的次数,否则输出"NO"。

样例输入:
7 4 3
4 1 3
0 0 0
样例输出:
NO
3

这个题一开始也是没什么思路。这些瓶子倒来倒去真实麻烦。后来反应过来应该用深搜或广搜来解决此类问题。深搜的代码写了一半,突然发觉还是用广搜更好些
代码如下
 #include <cstdio>
#include <iostream>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std; int v[][][]; int ans = -;
int s, n, m;
struct State
{
int a, b, c;
State(int a, int b, int c) {
this->a = a, this->b = b, this->c = c;
}
};
queue <State>que; int main(int argc, char const *argv[])
{ while (scanf("%d %d %d", &s, &n, &m) != EOF && (s != && n != && m != )) {
if (s & ) {
puts("NO");
}
else {
int ans = -;
memset(v, -, sizeof(v));
while (!que.empty()) {
que.pop();
}
que.push(State(s, , ));
v[s][][] = ;
while (!que.empty()) {
State p = que.front(); que.pop();
if ((p.a == p.b && p.a == s/) || (p.a == p.c && p.a == s/) || (p.b == p.c && p.b == s/)) {
ans = v[p.a][p.b][p.c];
break;
}
else {
int ra = s - p.a;
int rb = n - p.b;
int rc = m - p.c;
int step = v[p.a][p.b][p.c] + ;
if (ra > ) {
int tmp = min(ra, p.b);
int at = p.a + tmp;
int bt = p.b - tmp;
int ct = p.c;
if (v[at][bt][ct] == - || step < v[at][bt][ct]) {
if (tmp != ) {
que.push(State(at, bt, ct));
v[at][bt][ct] = step;
}
} tmp = min(ra, p.c);
at = p.a + tmp;
bt = p.b;
ct = p.c - tmp;
if (v[at][bt][ct] == - || step < v[at][bt][ct]) {
if (tmp != ) {
que.push(State(at, bt, ct));
v[at][bt][ct] = step;
}
} }
if (rb > ) {
int tmp = min(rb, p.a);
int at = p.a - tmp;
int bt = p.b + tmp;
int ct = p.c;
if (v[at][bt][ct] == - || step < v[at][bt][ct]) {
if (tmp != ) {
que.push(State(at, bt, ct));
v[at][bt][ct] = step;
}
} tmp = min(rb, p.c);
at = p.a;
bt = p.b + tmp;
ct = p.c - tmp;
if (v[at][bt][ct] == - || step < v[at][bt][ct]) {
if (tmp != ) {
que.push(State(at, bt, ct));
v[at][bt][ct] = step;
}
}
}
if (rc > ) {
int tmp = min(rc, p.a);
int at = p.a - tmp;
int bt = p.b ;
int ct = p.c + tmp;
if (v[at][bt][ct] == - || step < v[at][bt][ct]) {
if (tmp != ) {
que.push(State(at, bt, ct));
v[at][bt][ct] = step;
}
} tmp = min(rc, p.b);
at = p.a;
bt = p.b - tmp;
ct = p.c + tmp;
if (v[at][bt][ct] == - || step < v[at][bt][ct]) {
if (tmp != ) {
que.push(State(at, bt, ct));
v[at][bt][ct] = step;
}
}
}//if(rc)
}//else
}//while(queue)
if (ans == -) {
puts("NO");
}
else {
printf("%d\n", ans);
} }//else s is even
}//while(scanf)
return ;
}

九度oj 题目1457:非常可乐的更多相关文章

  1. 九度OJ 题目1384:二维数组中的查找

    /********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...

  2. hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人

    钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  3. 九度oj题目&amp;吉大考研11年机试题全解

    九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码).    http://ac.jobdu.com/problem.php?pid=11 ...

  4. 九度oj 题目1007:奥运排序问题

    九度oj 题目1007:奥运排序问题   恢复 题目描述: 按要求,给国家进行排名. 输入:                        有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...

  5. 九度oj 题目1087:约数的个数

    题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...

  6. 九度OJ题目1105:字符串的反码

    tips:scanf,cin输入字符串遇到空格就停止,所以想输入一行字符并保留最后的"\0"还是用gets()函数比较好,九度OJ真操蛋,true?没有这个关键字,还是用1吧,还是 ...

  7. 九度oj题目1009:二叉搜索树

    题目描述: 判断两序列是否为同一二叉搜索树序列 输入:                        开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束. 接 ...

  8. 九度oj题目1002:Grading

    //不是说C语言就是C++的子集么,为毛printf在九度OJ上不能通过编译,abs还不支持参数为整型的abs()重载 //C++比较正确的做法是#include<cmath.h>,cou ...

  9. 九度OJ题目1003:A+B

    while(cin>>str1>>str2)就行了,多简单,不得不吐槽,九度的OJ真奇葩 题目描述: 给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号", ...

随机推荐

  1. HTTP错误码汇总(转)

    响应码由三位十进制数字组成,它们出现在由HTTP服务器发送的响应的第一行.响应码分五种类型,由它们的第一位数字表示:1.1xx:信息,请求收到,继续处理2.2xx:成功,行为被成功地接受.理解和采纳3 ...

  2. wall命令

    wall——发送广播信息 write all /usr/bin/wall 示例1: # wall 输入命令之后回车便可以广播消息,如输入Hello everybody online后Ctrl+D结束并 ...

  3. 企业数字化转型与SAP云平台

    我们生活在一个数字化时代.信息领域里发展迅猛的数字技术和成本不断降低的硬件设备,正以前所未有的方式改变着我们工作和生活的方式. Digital Mesh 美国一家著名的从事信息技术研究和提供咨询服务的 ...

  4. codeforce Gym 100500A Poetry Challenge(博弈,暴搜)

    题解:状态压缩之后,暴力dfs,如果有一个选择,能让对手必败,那么就是必胜态,能转移到的状态都是对手的必胜态,或者无法转移,就是必败态. 总算是过了,TLE是因为状态没判重. #include< ...

  5. [课堂总结]C++课堂总结(二)

    近期的面向对象程序设计的不容易记忆或者理解的东西进行一个总结,以后忘记了可以常来看下,C++是个很重要的东西,很多领域都用得到,加油,特种兵! 浅拷贝构造.深拷贝构造 浅拷贝构造是系统默认的拷贝构造函 ...

  6. PHP程序Laravel框架的优化技巧

    Laravel是一套简洁.优雅的php Web开发框架(PHP Web Framework).它可以让你从杂乱的代码中解脱出来,可以帮你构建一个完美的网络app,而且每行代码都简洁.富于表达力.而性能 ...

  7. Xor Sum

    6498: Xor Sum 时间限制: 1 Sec  内存限制: 128 MB提交: 27  解决: 13[提交][状态][讨论版][命题人:admin] 题目描述 You are given a p ...

  8. 校招准备-关系型数据库与nosql

    深入理解常见的数据库的设计架构, 其中用到的数据结构, 算法等 SQL执行流程和优化, 可以了解一下calcite: https://calcite.apache.org/

  9. CPP-基础:类的静态成员

    一 静态数据成员:  类体中的数据成员的声明前加上static关键字,该数据成员就成为了该类的静态数据成员.和其他数据成员一样,静态数据成员也遵守public/protected/private访问规 ...

  10. vim 自动补全 颜色设置

    vim 自动补全 颜色设置 hi Pmenu ctermfg=black ctermbg=gray guibg=# hi PmenuSel ctermfg= ctermbg= guibg=# guif ...