大家一定觉的运动以后喝可乐是一件很惬意的事情,但是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暴力搜索可解。倒水只可能有六种情况,s->m s->n m->s m-->n n->s n->m 每种情况里分为能把待倒入的瓶子倒满和不能倒满。这里可以用一个结构体记录信息:s代表原瓶里的可乐容量,m代表m瓶里的,n代表n瓶里的,nxt代表下一次要往外倒可乐的瓶号(0代表s瓶,1代表m瓶,2代表n瓶),cnt代表倒可乐累积的次数。再建立一个vis数组判断是否访问过。要注意的是这里最好建四维数组,三维存s,m,n,第四维存nxt。BFS即可,注释写得很详细。

最后附上大佬的数论解法https://www.cnblogs.com/ECJTUACM-873284962/p/6750320.html

#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
using namespace std;
int s,n,m;
struct node
{
int s;
int m;
int n;
int cnt;
int nxt;//下一次该哪个杯子往外倒水 0 s 1 m 2 n
};
bool vis[][][][]={};//四维vis数组存是否访问过
int bfs()
{
node start;
start.s=s;
start.n=;//初始化第一层信息
start.m=;
start.cnt=;
start.nxt=;
queue<node>q;
q.push(start);
memset(vis,,sizeof(vis));
while(q.size())
{
node pre=q.front();
q.pop();
if((pre.s==pre.n&&pre.s==s/)||(pre.s==pre.m&&pre.s==s/)||(pre.n==pre.m&&pre.n==s/))//是否搜到
{
return pre.cnt;
}
if(vis[pre.s][pre.m][pre.n][pre.nxt])//访问过的话直接continue
{
continue;
}
vis[pre.s][pre.m][pre.n][pre.nxt]=;
int pour=pre.nxt;
node next;
if(pour==)//s往n m倒水
{
//s往n
if(n-pre.n<pre.s) //能倒满
{
next.s=pre.s-(n-pre.n);//更新下一层的信息
next.m=pre.m;
next.n=n;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);//不为0的话再添加 要不然瓶子里都没可乐了也就倒不出来了
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);//如果只是三维vis数组的话 加进去三个s m n一样但nxt不一样的 后两个都被vis判定卡掉了 所以要换成四维
}
else if(n-pre.n>=s)//不能倒满
{
next.s=;
next.m=pre.m;
next.n=pre.n+pre.s;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
}
//s往m
if(m-pre.m<pre.s)
{
next.s=pre.s-(m-pre.m);
next.n=pre.n;
next.m=m;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
}
else if(m-pre.m>=pre.s)
{
next.s=;
next.n=pre.n;
next.m=pre.m+pre.s;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
} }
else if(pour==)//m往 s n
{
//m往s
if(s-pre.s<pre.m)
{
next.m=pre.m-(s-pre.s);
next.n=pre.n;
next.s=s;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
}
else if(s-pre.s>=pre.m)
{
next.m=;
next.n=pre.n;
next.s=pre.s+pre.m;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
}
//m往n
if(n-pre.n<pre.m)
{
next.m=pre.m-(n-pre.n);
next.s=pre.s;
next.n=n;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
}
else if(n-pre.n>=pre.m)
{
next.m=;
next.s=pre.s;
next.n=pre.n+pre.m;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
}
}
else if(pour==)//n往s m
{
//n往s
if(s-pre.s<pre.n)
{
next.n=pre.n-(s-pre.s);
next.m=pre.m;
next.s=s;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
}
else if(s-pre.s>=pre.n)
{
next.n=;
next.m=pre.m;
next.s=pre.s+pre.n;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
}
//n往m
if(m-pre.m<pre.n)
{
next.n=pre.n-(m-pre.m);
next.s=pre.s;
next.m=m;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
}
else if(m-pre.m>=pre.n)
{
next.n=;
next.s=pre.s;
next.m=pre.m+pre.n;
next.cnt=pre.cnt+;
next.nxt=;
if(next.s!=)q.push(next);
next.nxt=;
if(next.m!=)q.push(next);
next.nxt=;
if(next.n!=)q.push(next);
}
}
}
return ;
}
int main()
{
while(scanf("%d%d%d",&s,&m,&n)&&s&&n&&m)
{
if(s%!=)
{
cout<<"NO"<<endl;
continue;
}
int ans=bfs();
if(ans)
{
cout<<ans<<endl;
continue;
}
else
{
cout<<"NO"<<endl;
continue;
}
}
return ;
}


HDU1495 非常可乐(BFS/数论)的更多相关文章

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

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

  2. HDU-1495 非常可乐(BFS)

    广搜的灵活应用题: 非常可乐 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) T ...

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

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

  4. HDU 1495 非常可乐 BFS

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

  5. HDU-1495 非常可乐 (嵌套结构体-广搜 对比 一般广搜)

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

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

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

  7. HDU1664 BFS + 数论 + 剪枝

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1664 , 一道比较蛋疼的搜索题. 这道题有很多坑点,一点处理不好就要TLE. 题意很简单,就是找到一个 ...

  8. (step4.2.5)hdu 1495(非常可乐——BFS)

    题目大意:输入三个整数 a,b,c.   a : 可乐瓶的容量,b: 甲杯的容量 ,c: 乙杯的容量.问能否用这三个被来实现饮料的平分???如果可以输出倒饮料的次数, 否则输出NO 解题思路:BFS ...

  9. HDU1495 非常可乐

    解题思路:简单的宽搜,见代码: #include<cstdio> #include<cstring> #include<algorithm> #include< ...

随机推荐

  1. centos7 sshpass 用法详解

    可以参考文章:https://www.cnblogs.com/kaishirenshi/p/7921308.html 安装方式直接通过yum 安装 yum -y install sshpass 常用的 ...

  2. 每天进步一点点------Allegro 建立封装的一般步骤

    在制作封装之前,先确定你需要的焊盘,如果库中没有,那就要自己画了,(我就是自己画的) 制作二极管1N5822 SMD,实际尺寸:480milX520mil 一.添加元件焊盘 1 启动Allegro P ...

  3. Pycharm调试django项目时发现断点失效

    解决方法: 第一步: 第二步: 点击 Edit Configuration 第三步 : 点击 + 选择python 填写相关参数信息 或者 点击ok  完成配置  重启 IDE 注意   重启IDE ...

  4. C语言数据结构——第三章 栈和队列

    三.栈和队列 栈和队列是两种重要的线性结构.从数据结构的角度来看,栈和队列也是线性表,它的特殊性在于栈和队列的基本操作是线性表操作的子集,它们的操作相对于线性表来说是受到限制的,因此,可以称其为限定性 ...

  5. android WebView缩放时卡顿问题

    问题描述: WebView 在双指缩放页面时会卡顿 解决过程:有试过打开硬件加速android:hardwareAccelerated="true" 还是没用,纠结了一天,最后屏蔽 ...

  6. nginx autoindex 配置目录浏览功能

    Nginx打开目录浏览功能 yum install httpd-tools -y cd /usr/local/openrestry/nginx/conf/ htpasswd -c passwd adm ...

  7. python的scribe client

    在网上找了一个python的scribe client使用方法 依赖的模块: pip install facebook-scribe pip install thrift 代码例子: #!/usr/b ...

  8. VMware克隆centos后需要进行修改配置的地方

    1. 首先在VMware中通过复制现在状态的虚拟机或者快照形式的虚拟机,选择完整复制文件进行克隆. 2.打开克隆的虚拟机之后,需要修改主机名和相应的hosts表 2.1 修改主机名 输入  vi /e ...

  9. Docker配置阿里云镜像源

    Docker默认拉取镜像是从这里拉取(https://hub.docker.com/),拉取的速度让人...,所以是配置国内镜像源,拉取速度十分惊人 一.版本要求 Docker版本:1.10以上 二. ...

  10. QT写的一个小工具:阿里云MQTT连接参数生成器.

    一.工具介绍. 最近在研究MQTT协议联网的一些问题,现在主流的物联网平台都支持MQTT协议. 在做阿里云平台连接测试的时候,连接参数的生成没有好用的工具, 所以就自己写了一个. 这个工具主要用于阿里 ...