HDU - 1495 非常可乐 bfs互倒三杯水
非常可乐
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 16071 Accepted Submission(s): 6488
4 1 3
0 0 0
3
#include<stdio.h>
#include<string.h>
#include<queue>
using namespace std; struct Node{
int x,y,z,s;
}node;
int bo[][][]; int main()
{
int a,b,c,i;
while(scanf("%d%d%d",&a,&b,&c)&&!(a==&&b==&&c==)){
if(a&){
printf("NO\n");
continue;
}
queue<Node> q;
memset(bo,,sizeof(bo));
bo[a][][]=;
node.x=a;
node.y=;
node.z=;
node.s=;
q.push(node);
int f=;
while(q.size()){
for(i=;i<=;i++){
int tx=q.front().x;
int ty=q.front().y;
int tz=q.front().z;
int ttx,tty,ttz;
if(i==){
ttx=tx>b-ty?tx-b+ty:;
tty=tx>b-ty?b:ty+tx;
ttz=tz;
}
if(i==){
ttx=tx>c-tz?tx-c+tz:;
tty=ty;
ttz=tx>c-tz?c:tz+tx;
}
if(i==){
ttx=ty>a-tx?a:tx+ty;
tty=ty>a-tx?ty-a+tx:;
ttz=tz;
}
if(i==){
ttx=tx;
tty=ty>c-tz?ty-c+tz:;
ttz=ty>c-tz?c:tz+ty;
}
if(i==){
ttx=tz>a-tx?a:tx+tz;
tty=ty;
ttz=tz>a-tx?tz-a+tx:;
}
if(i==){
ttx=tx;
tty=tz>b-ty?b:ty+tz;
ttz=tz>b-ty?tz-b+ty:;
}
if(ttx==a/&&(tty==a/||ttz==a/)){
f=q.front().s+;
break;
}
if(bo[ttx][tty][ttz]==){
bo[ttx][tty][ttz]=;
node.x=ttx;
node.y=tty;
node.z=ttz;
node.s=q.front().s+;
q.push(node);
}
}
if(f!=) break;
q.pop();
}
if(f==) printf("NO\n");
else printf("%d\n",f);
}
return ;
}
HDU - 1495 非常可乐 bfs互倒三杯水的更多相关文章
- HDU 1495 非常可乐 BFS 搜索
http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目就不说了, 说说思路! 倒可乐 无非有6种情况: 1. S 向 M 倒 2. S 向 N 倒 3. N ...
- (step4.2.5)hdu 1495(非常可乐——BFS)
题目大意:输入三个整数 a,b,c. a : 可乐瓶的容量,b: 甲杯的容量 ,c: 乙杯的容量.问能否用这三个被来实现饮料的平分???如果可以输出倒饮料的次数, 否则输出NO 解题思路:BFS ...
- HDU 1495 非常可乐 BFS搜索
题意:有个为三个杯子(杯子没有刻度),体积为s,n,m,s=m+n, 刚开始只有体积为s的杯子装满可乐,可以互相倒,问你最少的次数使可乐均分,如果没有结果,输出-1; 分析:直接互相倒就完了,BFS模 ...
- HDU 1495 非常可乐 bfs 难度:1
http://acm.hdu.edu.cn/showproblem.php?pid=1495 第三个杯子的盛水量可由前两个杯子得到,而前两个杯子状态总数在100*100以内,穷举可实现 #includ ...
- HDU 1495 非常可乐 BFS
题目大意:中文题不说了. 题目思路:我有同学用GCD数论写出来的代码很简洁,但是很抱歉,数论蒟蒻,我觉得比赛的时候我没办法推出.如果用BFS的话思路很简单的,就是6方向广搜,只不过稍微麻烦点.具体看代 ...
- BFS(倒水问题) HDU 1495 非常可乐
题目传送门 /* BFS:倒水问题,当C是奇数时无解.一共有六种情况,只要条件符合就入队,我在当该状态vised时写了continue 结果找了半天才发现bug,泪流满面....(网上找份好看的题解都 ...
- HDU 1495 非常可乐(数论,BFS)
非常可乐 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- 非常可乐---hdu 1495(BFS)
http://acm.hdu.edu.cn/showproblem.php?pid=1495 题意: 有3个杯子a b c:a=b+c:然后刚开始时只有a是满的,其它为空的,然后a b c三个之间互相 ...
- HDU 1495 非常可乐(BFS倒水问题)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 题目大意:只有两个杯子,它们的容量分别是N 毫升和M 毫升 可乐的体积为S (S<101) ...
随机推荐
- kubernetes之计算机资源管理
系列目录 当你编排一个pod的时候,你也可以可选地指定每个容器需要多少CPU和多少内存(RAM).当容器请求特定的资源时,调度器可以更好地根据资源请求来确定把pod调度到哪个节点上.当容器请求限制特定 ...
- caffe搭建--opensuse13.2上搭建caffe开发环境
第一部分:参考一下内容.将sudo 替换成zypper即可. --------------------------------------------这部分参照以下官网内容-------------- ...
- WPF控件模板和数据模板 - 醉意人间
来自:http://www.th7.cn/Program/WPF/2011/12/21/51676.shtml ControlTemplate用于描述控件本身. 使用TemplateBinding来绑 ...
- xml 基础属性
xml属性 对应的方法 说明 android:alpha setAlpha(float) 设置组件的透明度(0——1) android:background setBackgroundResource ...
- ubuntu:undefined reference to `snd_pcm_open'
这几天在做一个局域网的对讲机和广播系统. 需要用到alsa的库来进行音频采集和播放. 但是在编译程序的时候有个比较奇怪的问题. undefined reference to `snd_pcm_open ...
- 实用jQuery代码片段
maco精选的一些jQuery代码,也许你从中可以举一反三[代码] [JavaScript]代码001<p>002 <h3><span >★ 使用jQuery ...
- codeforces 467B Fedor and New Game 解题报告
题目链接:http://codeforces.com/contest/467/problem/B 题目意思:有 m + 1 个 player 和 n 种类型的 soldiers.每个player被赋予 ...
- BestCoder6 1002 Goffi and Squary Partition(hdu 4982) 解题报告
题目链接:http://bestcoder.hdu.edu.cn/contests/contest_showproblem.php?pid=1002&cid=530 (格式有一点点问题,直接粘 ...
- hdu 1004 Let the Balloon Rise 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1004 用STL 中的 Map 写的 #include <iostream> #includ ...
- 配置JDK和Tomcat环境变量(转)
1.安装JDK 安装好JDK后,再配置JDK的环境变量:在“我的电脑”上点右键—>“属性”—>“高级”—> “环境变量(N)”. 新建系统变量JAVA_HOME:C:/Program ...