非常可乐

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

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
 
思路:水杯A向水杯B到水的经典公式。 mn=min(B-now.b,now.a),na=now.a-mn,nb=now.b+mn.
#include <cstdio>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std;
const int MAXN=;
struct Node{
int s,n,m;
int step;
Node(){}
Node(int cs,int cn,int cm,int cstep)
{
s=cs;
n=cn;
m=cm;
step=cstep;
}
};
int vis[MAXN][MAXN][MAXN];
int S,N,M;
void bfs()
{
queue<Node> que;
que.push(Node(S,,,));
vis[S][N][M]=;
while(!que.empty())
{
Node now=que.front();que.pop();
if((now.s==&&now.n==now.m)||(now.n==&&now.s==now.m)||(now.m==&&now.s==now.n))
{
printf("%d\n",now.step);
return ;
}
int nes,nen,nem,mn;
mn=min(N-now.n,now.s);
nes=now.s-mn;
nen=now.n+mn;
nem=now.m;
if(!vis[nes][nen][nem])
{
vis[nes][nen][nem]=;
que.push(Node(nes,nen,nem,now.step+));
} mn=min(M-now.m,now.s);
nes=now.s-mn;
nen=now.n;
nem=now.m+mn;
if(!vis[nes][nen][nem])
{
vis[nes][nen][nem]=;
que.push(Node(nes,nen,nem,now.step+));
} mn=min(S-now.s,now.n);
nes=now.s+mn;
nen=now.n-mn;
nem=now.m;
if(!vis[nes][nen][nem])
{
vis[nes][nen][nem]=;
que.push(Node(nes,nen,nem,now.step+));
} mn=min(M-now.m,now.n);
nes=now.s;
nen=now.n-mn;
nem=now.m+mn;
if(!vis[nes][nen][nem])
{
vis[nes][nen][nem]=;
que.push(Node(nes,nen,nem,now.step+));
} mn=min(S-now.s,now.m);
nes=now.s+mn;
nen=now.n;
nem=now.m-mn;
if(!vis[nes][nen][nem])
{
vis[nes][nen][nem]=;
que.push(Node(nes,nen,nem,now.step+));
} mn=min(N-now.n,now.m);
nes=now.s;
nen=now.n+mn;
nem=now.m-mn;
if(!vis[nes][nen][nem])
{
vis[nes][nen][nem]=;
que.push(Node(nes,nen,nem,now.step+));
}
}
printf("NO\n");
}
int main()
{
while(scanf("%d%d%d",&S,&N,&M)!=EOF&&S&&N&&M)
{
memset(vis,,sizeof(vis));
if(S%!=)
{
printf("NO\n");
}
else bfs();
}
return ;
}
 

HDOJ1495(倒水BFS)的更多相关文章

  1. hdu1495 倒水bfs

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

  2. poj3414Pots(倒水BFS)

    Pots Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 13231   Accepted: 5553   Special J ...

  3. hdoj1495简单BFS

    #include <stdio.h> #include <string.h> #include <math.h> #include <algorithm> ...

  4. POJ 3414 Pots【bfs模拟倒水问题】

    链接: http://poj.org/problem?id=3414 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=22009#probl ...

  5. codevs1226倒水问题(Bfs)

    /* 首先建立模型 可以看成是三个水杯 第三个无穷大 (这里看成是201足够了) 最少步数 想到Bfs 维护队列里的状态:要有个步数 还要有v :此时刻三个杯子有多少水 然后倒水:因为没有刻度 所以有 ...

  6. HDU 1495 非常可乐(BFS倒水问题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目大意:只有两个杯子,它们的容量分别是N 毫升和M 毫升 可乐的体积为S (S<101) ...

  7. HDU 1495 非常可乐【BFS/倒水问题】

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

  8. CodeVS 1226 倒水问题【DFS/BFS】

    题目描述 Description 有两个无刻度标志的水壶,分别可装 x 升和 y 升 ( x,y 为整数且均不大于 100 )的水.设另有一水 缸,可用来向水壶灌水或接从水壶中倒出的水, 两水壶间,水 ...

  9. POJ - 3414 Pots BFS(著名倒水问题升级版)

    Pots You are given two pots, having the volume of A and B liters respectively. The following operati ...

随机推荐

  1. 数据处理 数据入数据库 与 Excel

    Python  数据处理   中间数据 Excel   团队交流分工   低的沟通成本    数据入数据库 如postgresql

  2. 页游手游服务器(五)sql缓存层

    sql的通用缓存,是实现最麻烦的一部分,对于查询结果的缓存,主要有如下的结构来缓存: cache tablename--player statement--select * from player w ...

  3. 我的Android进阶之旅------>如何获取系统中定义了那些权限

    在Window控制台中输入如下命令可以看到Android系统中列出的所有权限(如果自定义权限注册成功,在这里也会找到这些自定义的权限) adb shell pm list permissions C: ...

  4. JSP 分页代码

    jsp 分页模板 后台分页代码: 说明: 在 com.zc.domain 包下: PageBean.java 文件 package cn.itcast.customer.domain;   impor ...

  5. linux c编程:管道

    2在前面介绍过,进程之间交换信息的唯一途径就是传送打开的文件.可以经由fork或者exec来传送.这一章将介绍新的进程共享方式 每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都 ...

  6. Linux- 关于windows和Linux和Mac的换行符

    windows 的换行符为"\r\n" Linux的换行符为"\n" Mac的换行符为"\n\r",和Windows相反

  7. Hibernate学习---第十节:Hibernate之QBC、样例查询&离线查询

    一.QBC (Query By Criteria) 主要有Criteria,Criterion,Oder,Restrictions类组成 1.java 代码如下: /** * 查询所有 */ @Tes ...

  8. [深入学习C#]C#实现多线程的方式:使用Parallel类

    简介 在C#中实现多线程的另一个方式是使用Parallel类.  在.NET4中 ,另一个新增的抽象线程是Parallel类 .这个类定义了并行的for和foreach的 静态方法.在为 for和 f ...

  9. (转)C协程实现的效率对比

    前段时间实现的C协程依赖栈传递参数,在开启优化时会导致错误,于是实现了一个ucontext的版本,但ucontext的切换效率太差了, 在我的机器上执行4000W次切换需要11秒左右,这达不到我的要求 ...

  10. PS 滤镜——(扭曲)逆球面化 (凹陷效果)

    %%% Inverse_Spherize %%% 逆球面化 clc; clear all; close all; addpath('E:\PhotoShop Algortihm\Image Proce ...