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) ...
随机推荐
- Day1 [上]- 认识Python
python简单介绍: python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为AB ...
- JS 模板引擎 Handlebars.js 中文说明
Handlebars 为你提供了一个可以毫无挫折感的高效率书写 语义化的模板 所必需的一切. Mustache 模板和 Handlebars 是兼容的,所以你可以把Mustache模板拿来导入到Han ...
- Jquery放大镜插件---imgzoom.js(原创)
Jquery放大镜插件imgzoom能够实现图片放大的功能,便于与原图进行比较. 使用方法: 1.引入jQuery与imgzoom,imgzoom.css <link rel="sty ...
- EasyRTMP实现对接海康、大华等IPCamera SDK进行RTMP推送直播功能
本文转自EasyDarwin团队Kim的博客:http://blog.csdn.net/jinlong0603 Demo项目介绍 EasyRTMP Demo代码下载地址https://github.c ...
- Duilib学习之基础(一个SDK程序)
版权声明:本文为灿哥哥http://blog.csdn.net/caoshangpa原创文章,转载请标明出处. https://blog.csdn.net/caoshangpa/article/det ...
- window.onerror 错误监听,发到后台
var doc = document.body || document.documentElement; var _onerror = Onerror(''); var Onerror = funct ...
- Java其实不支持垃圾回收
Java其实不支持垃圾回收.如果真的支持的话,大多数Java程序在运行的一开始就应该把程序本身删除,因为这些程序本身就是垃圾. // TODO: This is a 分割线. Please no ...
- linux内核段属性机制【转】
本文转载自:https://github.com/TongxinV/oneBook/issues/9 linux内核段属性机制 以subsys_initcall和module_init为例 subsy ...
- javascrip中ajax
移动端对加载速度要求比较高,由于jquery插件有270多k,无形中增加加载的速度,下面整理一下原生js中ajax: 先了解ajax的基础知识 (1)XMLHttpRequest 对象 XMLHttp ...
- Codeforces Round #369 (Div. 2) D. Directed Roads —— DFS找环 + 快速幂
题目链接:http://codeforces.com/problemset/problem/711/D D. Directed Roads time limit per test 2 seconds ...