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

有六种状态,从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. JDK1.7的一些新特性

    整理了几条对开发可能用到概率高的 1.swicth支持对String的判断:(以前只能支持Int及以下的) switch (s) { case "1": break; case & ...

  2. html 链接外部css js文件

    <link rel="stylesheet" type="text/css" href/style.css" />    <scri ...

  3. 在Loadrunner中如何用system函数执行系统命令

    前提: windows 系统 实现功能:用 LR 中的system函数执行系统命令 相关功能:在LR中利用C函数建立文件,写文件,读文件. 主要相关函数:sprintf/fopen/fgetc/fre ...

  4. 转:eclipse里面显示中文乱码

    显示中文会变成乱码解决方案:Windows- >Pereferences- >General->Workspace- >Text   File   Encoding   选项下 ...

  5. 普通spring jsp+mybatis项目修改为springboot + jsp +mybatis项目

    概述 由于公司决定使用spring cloud,但是公司积累了大量的普通的jsp项目,老的项目直接全部修改为springboot成本过高,周期比较长,而且公司业务正在快速拓展,所以需要把之前的老项目修 ...

  6. 【LeetCode】132. Palindrome Partitioning II

    Palindrome Partitioning II  Given a string s, partition s such that every substring of the partition ...

  7. Java虚拟机学习 - 垃圾收集器 (4)

    HotSpot JVM收集器 上面有7中收集器,分为两块,上面为新生代收集器,下面是老年代收集器.如果两个收集器之间存在连线,就说明它们可以搭配使用. Serial(串行GC)收集器 Serial收集 ...

  8. 制作IOS 后台极光推送时,遇到的小问题

    推送广义上分为两种, 一种是  程序在前台的时候,不想在任务栏里面显示通知,直接在app中进行某种操作.这个叫做自定义消息.这个是在前台时,app与极光后台建立了一个长链接. 另一种是  程序处于前. ...

  9. 2.Java基础:方法定义和调用

    一.方法的定义 1.类的方法代表的是实力的某种行为(或功能) 方法的定义:方法类型 . 方法签名 . 方法体 2.定义类的方法 访问修饰符 类型 方法名(参数列表){ ///方法体 } 3.把方法当作 ...

  10. BIP_BI Pubisher的SQL/XSL/FO扩展函数应用(概念)

    2014-12-01 Created By BaoXinjian