非常可乐

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 3510    Accepted Submission(s): 1440

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

这是一题搜索题,bfs,我的思路是分为A->B , A->C , B->A , B->C , C->B , C->A 六种情况,后面4种情况,要考虑是否溢出,,,仔细一点就不会错了,哈哈

附上我的代码,有什么更好的方法,请多多指教,                                                            ps:原题 http://acm.hdu.edu.cn/showproblem.php?pid=1495

#include<iostream>
#include<queue>
#include<cstring>
using namespace std;
int visit[][][];
int s,m,n; struct node
{
int x,y,z;
int step;
}; void bfs()
{
queue<node>Q;
node now,next;
now.x=s;
now.y=;
now.z=;
visit[now.x][now.y][now.z]=;
now.step=;
Q.push(now);
while(!Q.empty())
{
now=Q.front();
Q.pop();
if((now.x==s/&&now.x==now.y)||(now.x==s/&&now.x==now.z)||(now.y==s/&&now.y==now.z))//到达评分条件的时候跳出
{
printf("%d\n",now.step);
return ;
}
if(now.x != ) //A->B,A->C
{
if(now.y != n)
{
next.x = now.x - (n - now.y);
next.y = n;
next.z = now.z; if(!visit[next.x][next.y][next.z])
{
next.step = now.step + ;
Q.push(next);
visit[next.x][next.y][next.z] = ;
}
}
if(now.z != m)
{
next.x = now.x - (m - now.z);
next.y = now.y;
next.z = m; if(!visit[next.x][next.y][next.z])
{
next.step = now.step + ;
Q.push(next);
visit[next.x][next.y][next.z] = ;
}
}
}
if(now.y != ) //B->A,B->C
{
next.x = now.x + now.y;
next.y = ;
next.z = now.z; if(!visit[next.x][next.y][next.z])
{
next.step = now.step + ;
Q.push(next);
visit[next.x][next.y][next.z] = ;
}
if(now.y < m - now.z)
{
next.x = now.x;
next.y = ;
next.z = now.y + now.z;
if(!visit[next.x][next.y][next.z])
{
next.step = now.step + ;
Q.push(next);
visit[next.x][next.y][next.z] = ;
}
}
else
{
next.x = now.x;
next.y = now.y - (m - now.z);
next.z = m;
if(!visit[next.x][next.y][next.z])
{
next.step = now.step + ;
Q.push(next);
visit[next.x][next.y][next.z] = ;
}
}
}
if(now.z != ) //C->A,C->B
{
next.x = now.x + now.z;
next.y = now.y;
next.z = ;
if(!visit[next.x][next.y][next.z])
{
next.step = now.step + ;
Q.push(next);
visit[next.x][next.y][next.z] = ;
}
if(now.z < n - now.y)
{
next.x = now.x;
next.y = now.y + now.z;
next.z = ;
if(!visit[next.x][next.y][next.z])
{
next.step = now.step + ;
Q.push(next);
visit[next.x][next.y][next.z] = ;
}
}
else
{
next.x = now.x;
next.y = n;
next.z = now.z - (n - now.y);
if(!visit[next.x][next.y][next.z])
{
next.step = now.step + ;
Q.push(next);
visit[next.x][next.y][next.z] = ;
}
}
} }
printf("NO\n");
}
int main()
{
while(scanf("%d%d%d",&s,&n,&m)!=EOF&&n||m||s)
{
memset(visit,,sizeof(visit));
if(s%==)//s为奇数是不可能平分的,可优化。
bfs();
else
printf("NO\n");
}
return ;
}

代码有点冗长啊,不过有很多是重复的,求更好的方法!欢迎评论

非常可乐(杭电hdu1495)bfs的更多相关文章

  1. 杭电ACM分类

    杭电ACM分类: 1001 整数求和 水题1002 C语言实验题——两个数比较 水题1003 1.2.3.4.5... 简单题1004 渊子赛马 排序+贪心的方法归并1005 Hero In Maze ...

  2. 杭电ACM题单

    杭电acm题目分类版本1 1002 简单的大数 1003 DP经典问题,最大连续子段和 1004 简单题 1005 找规律(循环点) 1006 感觉有点BT的题,我到现在还没过 1007 经典问题,最 ...

  3. 『ACM C++』HDU杭电OJ | 1415 - Jugs (灌水定理引申)

    今天总算开学了,当了班长就是麻烦,明明自己没买书却要带着一波人去领书,那能怎么办呢,只能说我善人心肠哈哈哈,不过我脑子里突然浮起一个念头,大二还要不要继续当这个班委呢,既然已经体验过就可以适当放下了吧 ...

  4. acm入门 杭电1001题 有关溢出的考虑

    最近在尝试做acm试题,刚刚是1001题就把我困住了,这是题目: Problem Description In this problem, your task is to calculate SUM( ...

  5. 杭电acm 1002 大数模板(一)

    从杭电第一题开始A,发现做到1002就不会了,经过几天时间终于A出来了,顺便整理了一下关于大数的东西 其实这是刘汝佳老师在<算法竞赛 经典入门 第二版> 中所讲的模板,代码原封不动写上的, ...

  6. 杭电OJ——1198 Farm Irrigation (并查集)

    畅通工程 Problem Description 某省调查城镇交通状况,得到现有城镇道路统计表,表中列出了每条道路直接连通的城镇.省政府"畅通工程"的目标是使全省任何两个城镇间都可 ...

  7. 高手看了,感觉惨不忍睹——关于“【ACM】杭电ACM题一直WA求高手看看代码”

    按 被中科大软件学院二年级研究生 HCOONa 骂为“误人子弟”之后(见:<中科大的那位,敢更不要脸点么?> ),继续“误人子弟”. 问题: 题目:(感谢 王爱学志 网友对题目给出的翻译) ...

  8. C#利用POST实现杭电oj的AC自动机器人,AC率高达50%~~

    暑假集训虽然很快乐,偶尔也会比较枯燥,,这个时候就需要自娱自乐... 然后看hdu的排行榜发现,除了一些是虚拟测评机的账号以外,有几个都是AC自动机器人 然后发现有一位作者是用网页填表然后按钮模拟,, ...

  9. 杭电ACM2076--夹角有多大(题目已修改,注意读题)

    杭电ACM2076--夹角有多大(题目已修改,注意读题) http://acm.hdu.edu.cn/showproblem.php?pid=2076 思路很简单.直接贴代码.过程分析有点耗时间. / ...

随机推荐

  1. Linux启动流程与模块管理(15)

    系统的启动其实是一项非常复杂的过程,因为内核得要检测硬件并加载适当的驱动程序,接下来则必须要调用程序来准备好系统运行的环境,以让用户能够顺利的操作整台主机系统,如果你能够理解系统启动的原理,那么将有助 ...

  2. sublime text 文件打开时回调一些函数

    需求:公司服务端脚本以 .s 结尾的文件,也按 js 语法识别,方便查看函数定义. 每次都 ss:js 比较麻烦,所以写个插件. import sublime, sublime_plugin clas ...

  3. per学习笔记-zkclient,curator使用

    开源客户端,原生api的不足 连接的创建是异步的,需要开发人员自行编码实现等待 连接没有自动的超时重连机制 Zk本身没提供序列化机制,需要开发人员自行指定,从而实现数据的序列化和反序列化 Watche ...

  4. postgresql-定时备份,压缩备份

    crontab -e 在最后添加: # backup database at 22:00 every day 0 22 * * * thunisoft /home/eric/bin/backup-db ...

  5. opencv2.4.13.7的resize函数使用(c++)

    先来看一下resize函数的原型,如下. C++: void resize(InputArray src, OutputArray dst, Size dsize, double fx=0, doub ...

  6. static、final、static final的区别

    final: final可以修饰属性,方法,类,局部变量(方法中的变量) final修饰的属性的初始化可以在编译期,也可以在运行期,初始化后不能被改变. final修饰的属性跟具体对象有关,在运行期初 ...

  7. vue教程1-03 v-for循环

    vue教程1-03 v-for循环 v-for循环: v-for="name in arr" {{value}} {{$index}} v-for="name in js ...

  8. Why does Http header contains "X-SourceFiles"?

    Question: Using a FileStreamResult in ASP.NET MVC 3, I get a response header like X-SourceFiles =?UT ...

  9. 基于GTK+3 开发远程控制管理软件(C语言实现)系列三 Windows7开发环境搭建

    一.介绍与准备 考虑到目标客户端基本都是windows客户端,所以此次开发环境将搭建在windows7下,相关开发工具有Msys2 和 Eclipse For C/C++ Msys2 是msys的升级 ...

  10. c++中的复合类型

    复合类型是指基于其他类型而定义的类型. 而这里介绍的是引用和指针.并且指针和引用都提供了对其他对象的间接访问. 引用 引用还是很好理解的,就是为对象起了另外一个名字,引用类型引用另外一种类型. 通常将 ...