非常可乐

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

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里面就行了

代码1:

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<queue>
using namespace std;
const int INF=0x3f3f3f3f;
int S,M,N;
int vis[][];
struct Node{
int s,m,n,step;
};
bool check(Node a){
int x,y,z;
x=a.s;y=a.m;z=a.n;
int flot=;
if(!x)flot++;if(!y)flot++;if(!z)flot++;
if(flot!=)return false;
flot=;
if(x)if(x*==S)flot++;
if(y)if(y*==S)flot++;
if(z)if(z*==S)flot++;
if(flot==)return true;
else return false;
}
void bfs(){
Node a,b;
memset(vis,,sizeof(vis));
queue<Node>dl;
a.s=S;
a.m=;
a.n=;
a.step=;
dl.push(a);
vis[a.m][a.n]=;
while(!dl.empty()){
a=dl.front();
dl.pop();
if(a.m<M){//s-m
if(a.s>=M-a.m){
b.s=a.s-(M-a.m);
b.m=M;
b.n=a.n;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
else{
b.m=a.m+a.s;
b.s=;
b.n=a.n;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
}
if(a.n<N){//s-n
if(a.s>=N-a.n){
b.s=a.s-(N-a.n);
b.n=N;
b.m=a.m;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
else{
b.n=a.n+a.s;
b.s=;
b.m=a.m;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
}
if(a.s<S){//m-s
if(a.m>=S-a.s){
b.m=a.m-(S-a.s);
b.s=S;
b.n=a.n;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
else{
b.s=a.s+a.m;
b.n=a.n;
b.m=;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
}
if(a.n<N){//m-n
if(a.m>=N-a.n){
b.m=a.m-(N-a.n);
b.s=a.s;
b.n=N;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
else{
b.n=a.n+a.m;
b.s=a.s;
b.m=;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
}
if(a.s<S){//n-s
if(a.n>=S-a.s){
b.n=a.n-(S-a.s);
b.s=S;
b.m=a.m;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
else{
b.s=a.s+a.n;
b.m=a.m;
b.n=;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
}
if(a.m<M){//n-m
if(a.n>=M-a.m){
b.n=a.n-(M-a.m);
b.s=a.s;
b.m=M;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
else{
b.m=a.m+a.n;
b.s=a.s;
b.n=;
b.step=a.step+;
if(check(b)){
printf("%d\n",b.step);
return;
}
if(!vis[b.m][b.n]){
vis[b.m][b.n]=;
dl.push(b);
}
}
}
}
puts("NO");
}
int main(){
while(~scanf("%d%d%d",&S,&M,&N),S|M|N){
if(S&)puts("NO");
else bfs();
}
return ;}

代码2:

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<queue>
using namespace std;
const int INF=0x3f3f3f3f;
int c[];
int vis[][];
struct Node{
int v[],step;
};
bool check(Node a){
int x,y,z;
x=a.v[];y=a.v[];z=a.v[];
int t=c[]/;
//printf("%d %d %d %d\n",x,y,z,t);
if(x==t&&y==t)return true;
if(y==t&&z==t)return true;
if(x==t&&z==t)return true;
return false;
}
void bfs(){
Node a,b;
memset(vis,,sizeof(vis));
queue<Node>dl;
a.v[]=c[];
a.v[]=;
a.v[]=;
a.step=;
dl.push(a);
vis[a.v[]][a.v[]]=;
while(!dl.empty()){
a=dl.front();
dl.pop();
for(int i=;i<;i++)
for(int j=;j<;j++){
if(i==j)continue;
b=a;
b.step=a.step+;
if(b.v[i]>=c[j]-b.v[j]){
b.v[i]=b.v[i]-(c[j]-b.v[j]);
b.v[j]=c[j];
}
else{
b.v[j]+=b.v[i];
b.v[i]=;
}
if(check(b)){
printf("%d\n",b.step);return;
}
if(!vis[b.v[]][b.v[]]){
dl.push(b);vis[b.v[]][b.v[]]=;
}
}
}
puts("NO");
}
int main(){
while(~scanf("%d%d%d",c,c+,c+),c[]|c[]|c[]){
if(c[]&)puts("NO");
else bfs();
}
return ;}

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

  1. HDU1459 非常可乐(BFS) 2016-07-24 15:00 165人阅读 评论(0) 收藏

    非常可乐 Problem Description 大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为.因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶 ...

  2. HDU1495 非常可乐 —— BFS + 模拟

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 非常可乐 Time Limit: 2000/1000 MS (Java/Others)    M ...

  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 搜索

    http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目就不说了, 说说思路! 倒可乐 无非有6种情况: 1. S 向 M 倒 2. S 向 N 倒 3. N ...

  6. hdu_1495_非常可乐(bfs模拟)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 题意:不解释 题解:BFS模拟,不过要细心,把所有情况都列举出来,开一个数组记录状态,代码有点长 ...

  7. HDU 1495 非常可乐 BFS

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

  8. HDU-1459.非常可乐(BFS )

    这道题TLE了很多次,原来一直以为将数字化为最简可以让运算更快,但是去了简化之后才发现,真正耗时的就是化简....还和队友学到了用状态少直接数组模拟刚就能过... 本题大意:给出可乐的体积v1,给出两 ...

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

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

  10. HDU 1495 非常可乐 bfs 难度:1

    http://acm.hdu.edu.cn/showproblem.php?pid=1495 第三个杯子的盛水量可由前两个杯子得到,而前两个杯子状态总数在100*100以内,穷举可实现 #includ ...

随机推荐

  1. Hadoop学习之Mapreduce执行过程详解

    一.MapReduce执行过程 MapReduce运行时,首先通过Map读取HDFS中的数据,然后经过拆分,将每个文件中的每行数据分拆成键值对,最后输出作为Reduce的输入,大体执行流程如下图所示: ...

  2. Linux 下修改Tomcat使用的JVM内存大小

    我的服务器的配置: # OS specific support.  $var _must_ be set to either true or false. JAVA_OPTS="-Xms10 ...

  3. Linux Kernel 2.6.28 以上有BUG,系统运行第208.5天down机

    简介: 业务服务器有一台服务器出现意外down机,服务器ping 不通.无法登陆,本想通过公司KVM系统登陆系统重启解决,登陆KVM后发现系统屏幕打印大量的内核错误,KVM无法使用.无法发送重启服务器 ...

  4. VC++深入详解-第五章学习心得

    这一章节主要讲解了文本相关的一些编程 插入符的使用 CreateSolidCaret(100,200);//插入符的宽度和高度 ShowCaret(); 插入符的一般使用方法 int CTestVie ...

  5. 物理DG主备库切换时遇到ORA-16139: media recovery required错误

    在物理DG主备库切换时遇到ORA-16139: media recovery required错误 SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO PRI ...

  6. java基于P2P的聊天和文件传输实例

    用java的NIO技术编写的 1. 支持聊天功能 2. 拖拽文件能够实现文件传输功能.也能够是目录 3. 启动时能够选择server端或client端启动 4. 本人原创.学习NIO和java的网络通 ...

  7. CSS learnning...

    "Whenever this property changes, apply that change slowly." The property transition: width ...

  8. js 去除字符串左右两端的空格

    <script type="text/javascript"> function trim(str){ //删除左右两端的空格      return str.repl ...

  9. 当前项目与当前环境的JDK版本不匹配”Bad version number in .class file“

    java.lang.UnsupportedClassVersionError: Bad version number in .class file at java.lang.ClassLoader.d ...

  10. error 和 exception 有什么区别?

    1.error指恢复不是不可能但非常困难的情况下的一种严重错误.比如内存溢出,不指望程序可以处理这样的情况. 2.exception表示一种设计或者实现问题,如果程序正常运行,则从不会发生.