九度oj 题目1457:非常可乐
- 题目描述:
-
大家一定觉的运动以后喝可乐是一件很惬意的事情,但是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:非常可乐的更多相关文章
- 九度OJ 题目1384:二维数组中的查找
/********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...
- hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人
钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- 九度oj题目&吉大考研11年机试题全解
九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码). http://ac.jobdu.com/problem.php?pid=11 ...
- 九度oj 题目1007:奥运排序问题
九度oj 题目1007:奥运排序问题 恢复 题目描述: 按要求,给国家进行排名. 输入: 有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...
- 九度oj 题目1087:约数的个数
题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...
- 九度OJ题目1105:字符串的反码
tips:scanf,cin输入字符串遇到空格就停止,所以想输入一行字符并保留最后的"\0"还是用gets()函数比较好,九度OJ真操蛋,true?没有这个关键字,还是用1吧,还是 ...
- 九度oj题目1009:二叉搜索树
题目描述: 判断两序列是否为同一二叉搜索树序列 输入: 开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束. 接 ...
- 九度oj题目1002:Grading
//不是说C语言就是C++的子集么,为毛printf在九度OJ上不能通过编译,abs还不支持参数为整型的abs()重载 //C++比较正确的做法是#include<cmath.h>,cou ...
- 九度OJ题目1003:A+B
while(cin>>str1>>str2)就行了,多简单,不得不吐槽,九度的OJ真奇葩 题目描述: 给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号", ...
随机推荐
- SQL Server数据库所有表重建索引
USE My_Database;DECLARE @name varchar(100) DECLARE authors_cursor CURSOR FOR Select [name] from s ...
- LibreOJ #514. 「LibreOJ β Round #2」模拟只会猜题意
内存限制:256 MiB 时间限制:1000 ms 标准输入输出 题目类型:传统 评测方式:文本比较 题目描述 给定一个长度为 nnn 的序列 AAA . 定义 f(l,r)=∑i=lrAif(l,r ...
- 微软分布式机器学习工具包DMTK——初窥门径
在现在机器学习如日中天的大背景下,微软亚洲研究院的实习岗位中,机器学习组的工作也是维护DMTK,参与算法改进,那么在此之前我们得了解DMTK是个啥. DMTK由一个服务于分布式机器学习的框架和一组分布 ...
- 最新电脑公司最新GHOST WIN7系统32,64位极速安全版
系统来自系统妈:http://www.xitongma.com 电脑公司最新GHOST win7系统64位极速安全版 V2016年3月 系统简介 电脑公司ghost win7系统64位极速安全版集成了 ...
- AJAX不能访问MVC后台程序的问题
AJAX不能访问后台的MVC有可能是MVC的后台程序加入了身份验证[Authorize]标记,这样前台的AJAX虽然结果显示的是4和200但是responsetext的值可以看到是返回了一个配置文件中 ...
- 自实现RPC调用
服务提供者 服务接口: public interface HelloService { public String sayHello(String name); } 服务实现类: public cla ...
- shell脚本,awk取奇数行与偶数行方法。
第一种方法: 第二种方法: 第三种方法:
- fiddler 模拟发送post请求
打开fiddler,选择在右边的Composer工具栏,打开Parsed选项,然后数据发送协议,例如选择POST, POST右边输入框可以输入访问地址, 下方的输入框可以输入发送的输入操作,例如发送的 ...
- js函数式编程(二)-柯里化
这节开始讲的例子都使用简单的TS来写,尽量做到和es6差别不大,正文如下 我们在编程中必然需要用到一些变量存储数据,供今后其他地方调用.而函数式编程有一个要领就是最好不要依赖外部变量(当然允许通过参数 ...
- css文件和js文件后面带一个问号----2015-1103
经常看一些网站页面源代码中的css文件和js文件后面带一个问号,后面跟着一连串数字或字符,这是干什么用的? 这个方法我也用过,而且很好用?,它的作用有两个:1.作为版本号,让自己方便记忆.查找:2.作 ...