思路:搜索题,第一次做这种类型的题目吧,一开始表示不怎么明白题意所说的东东。其实就是要你判断可乐能不能被平分........

有六种状态,从a瓶到b瓶,a-->c

b-->a     b-->c

c-->a     c-->b

然后每种状态里面又分两种不同情况,可以将此瓶的水全部清空,不能清空......

然后广搜就可以了........

#include<iostream>
#include<stdio.h>
#include<string.h>
#include<queue>
using namespace std;
int vist[105][105][105],a,b,c;
struct node
{
int a,b,c;
int step;
}s[105];
int sum=0;
void bfs()
{
queue<node>q;
memset(vist,0,sizeof(vist));
node p1;
p1.a=a;
p1.b=0;
p1.c=0;
p1.step=0;
q.push(p1);
vist[p1.a][0][0]=1;
while(!q.empty())
{
p1=q.front();
q.pop();
if((p1.a==a/2&&p1.b==a/2)||(p1.a==a/2&&p1.c==a/2)||(p1.b==a/2&&p1.c==a/2))
{
printf("%d\n",p1.step);
return;
}
node p2;
if(p1.a!=0)
{
if(p1.a>b-p1.b)
{
p2.a=p1.a-(b-p1.b);
p2.b=b;
p2.c=p1.c;
p2.step=p1.step+1;
}
else
{
p2.a=0;
p2.b=p1.b+p1.a;
p2.c=p1.c;
p2.step=p1.step+1;
}
if(!vist[p2.a][p2.b][p2.c])
{
vist[p2.a][p2.b][p2.c]=1;
q.push(p2);
}
} if(p1.a!=0)
{
if(p1.a>c-p1.c)
{
p2.a=p1.a-(c-p1.c);
p2.b=p1.b;
p2.c=c;
p2.step=p1.step+1;
}
else
{
p2.a=0;
p2.b=p1.b;
p2.c=p1.c+p1.a;
p2.step=p1.step+1;
}
if(!vist[p2.a][p2.b][p2.c])
{
vist[p2.a][p2.b][p2.c]=1;
q.push(p2);
}
} if(p1.b!=0)
{
if(p1.b>a-p1.a)
{
p2.b=p1.b-(a-p1.a);
p2.a=a;
p2.c=p1.c;
p2.step=p1.step+1;
}
else
{
p2.b=0;
p2.a=p1.a+p1.b;
p2.c=p1.c;
p2.step=p1.step+1;
}
if(!vist[p2.a][p2.b][p2.c])
{
vist[p2.a][p2.b][p2.c]=1;
q.push(p2);
}
} if(p1.b!=0)
{
if(p1.b>c-p1.c)
{
p2.b=p1.b-(c-p1.c);
p2.a=p1.a;
p2.c=c;
p2.step=p1.step+1;
}
else
{
p2.b=0;
p2.a=p1.a;
p2.c=p1.c+p1.b;
p2.step=p1.step+1;
}
if(!vist[p2.a][p2.b][p2.c])
{
vist[p2.a][p2.b][p2.c]=1;
q.push(p2);
}
} if(p1.c!=0)
{
if(p1.c>a-p1.a)
{
p2.c=p1.c-(a-p1.a);
p2.a=a;
p2.b=p1.b;
p2.step=p1.step+1;
}
else
{
p2.c=0;
p2.a=p1.a+p1.c;
p2.b=p1.b;
p2.step=p1.step+1;
}
if(!vist[p2.a][p2.b][p2.c])
{
vist[p2.a][p2.b][p2.c]=1;
q.push(p2);
}
} if(p1.c!=0)
{
if(p1.c>b-p1.b)
{
p2.c=p1.c-(b-p1.b);
p2.a=p1.a;
p2.b=b;
p2.step=p1.step+1;
}
else
{
p2.c=0;
p2.a=p1.a;
p2.b=p1.b+p1.c;
p2.step=p1.step+1;
}
if(!vist[p2.a][p2.b][p2.c])
{
vist[p2.a][p2.b][p2.c]=1;
q.push(p2);
}
}
}
printf("NO\n");
}
int main()
{
while(scanf("%d%d%d",&a,&b,&c)>0&&(a+b+c))
{
if(a%2==1)
{
printf("NO\n");
continue;
}
bfs();
}
return 0;
}

hdu1495(经典bfs,平分水问题)的更多相关文章

  1. NYOJ 21.三个水杯-初始态到目标态的最少次数-经典BFS

    题目传送门:biubiubiu~ 三个水杯 时间限制:1000 ms  |  内存限制:65535 KB 难度:4   描述 给出三个水杯,大小不一,并且只有最大的水杯的水是装满的,其余两个为空杯子. ...

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

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

  3. hdu1495 倒水bfs

    题目链接:http://icpc.njust.edu.cn/Problem/Hdu/1495/ 题意:给定三个杯子S,M,N,满足S=M+N,现在要求用最短的次数将S杯中的饮倒平分到两个杯子中.我们首 ...

  4. LightOJ 1012 简单bfs,水

    1.LightOJ 1012  Guilty Prince  简单bfs 2.总结:水 题意:迷宫,求有多少位置可去 #include<iostream> #include<cstr ...

  5. HDOJ/HDU 1242 Rescue(经典BFS深搜-优先队列)

    Problem Description Angel was caught by the MOLIGPY! He was put in prison by Moligpy. The prison is ...

  6. hdu1495(bfs)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 题意:有三个杯子,开始时第一个杯子装满水(体积为a),倒来倒去,得到其中2个杯里的水的体积都为a ...

  7. 非常可乐(杭电hdu1495)bfs

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

  8. POJ 3278 经典BFS

    进一步了解了bfs; 题意:给你n,然后用+,-,*三种运算使n变成k; 漏洞:在算出新的数字之后,一定要判边界,否则RE,而且在每一步后面都得加判断是否等于K,如果是即刻退出,否则WA,判这个的时候 ...

  9. POJ 3369 Meteor Shower (BFS,水题)

    题意:给定 n 个炸弹的坐标和爆炸时间,问你能不能逃出去.如果能输出最短时间. 析:其实这个题并不难,只是当时没读懂,后来读懂后,很容易就AC了. 主要思路是这样的,先标记所有的炸弹的位置,和时间,在 ...

随机推荐

  1. Linux安装Nginx1.7.4、php5.5.15和配置

    Nginx是一个轻量级的高性能Webserver.反向代理server.邮件(IMAP/POP3/SMTP)server,是Igor Sysoev为俄罗斯訪问量第二的Rambler.ru网站开发,第一 ...

  2. Web Service——CXF

    1. 什么是CXF Apache CXF = Celtix + Xfire,开始叫 Apache CeltiXfire,后来更名为 Apache CXF 了,以下简称为 CXF.Apache CXF ...

  3. HDUOJ--1058HangOver

    HangOver Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  4. iOS 9 适配中出现的坑

    整理 iOS 9 适配中出现的坑(图文) 2015-10-22 iOS开发 库克表示:“现在在中国有150多万的开发者在iOS当中开发应用程序,我们鼓励更多的人开发应用程序,也鼓励更多的创业加入.” ...

  5. XP和Win 7双系统安装说明和注意事项

    安装前说明: 1.先装XP,再装Windows 7,最好不要反过来,不然XP不会把Windows 7的启动管理器给覆盖掉,会麻烦些.总之遵循“旧版本到新版本”安装原则. 2.如果分区不够大,请用以下软 ...

  6. python学习笔记——创建事件对象Event

    1 Event对象的基本概述 用 multiprocessing.Event 实现线程间通信,使用multiprocessing.Event可以使一个线程等待其他线程的通知,我们把这个Event传递到 ...

  7. regular expression 练习

    练习有一个文件,文件名为output_1981.10.21.txt .下面使用Python: 读取文件名中的日期时间信息,并找出这一天是周几.将文件改名为output_YYYY-MM-DD-W.txt ...

  8. Linux中断 - tasklet

    一.前言 对于中断处理而言,linux将其分成了两个部分,一个叫做中断handler(top half),属于不那么紧急需要处理的事情被推迟执行,我们称之deferable task,或者叫做bott ...

  9. linux write系统调用如何实现

    在Linux下我们在使用设备的时候,都会用到write这个函数,通过这个函数我们可以象使用文件那样向设备传送数据.可是为什么用户使用write函数就可以把数据写到设备里面去,这个过程到底是怎么实现的呢 ...

  10. Linux内核(5) - 内核学习的相关资源

    “世界上最缺的不是金钱,而是资源.”当我在一份报纸上看到这句大大标题时,我的第一反应是——作者一定是个自然环保主义者,然后我在羞愧得反省自身的同时油然生出一股对这样的无产主义理想者无比崇敬的情绪来. ...