hdu1495(经典bfs,平分水问题)
思路:搜索题,第一次做这种类型的题目吧,一开始表示不怎么明白题意所说的东东。其实就是要你判断可乐能不能被平分........
有六种状态,从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,平分水问题)的更多相关文章
- NYOJ 21.三个水杯-初始态到目标态的最少次数-经典BFS
题目传送门:biubiubiu~ 三个水杯 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 给出三个水杯,大小不一,并且只有最大的水杯的水是装满的,其余两个为空杯子. ...
- HDU1495 非常可乐 —— BFS + 模拟
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 非常可乐 Time Limit: 2000/1000 MS (Java/Others) M ...
- hdu1495 倒水bfs
题目链接:http://icpc.njust.edu.cn/Problem/Hdu/1495/ 题意:给定三个杯子S,M,N,满足S=M+N,现在要求用最短的次数将S杯中的饮倒平分到两个杯子中.我们首 ...
- LightOJ 1012 简单bfs,水
1.LightOJ 1012 Guilty Prince 简单bfs 2.总结:水 题意:迷宫,求有多少位置可去 #include<iostream> #include<cstr ...
- HDOJ/HDU 1242 Rescue(经典BFS深搜-优先队列)
Problem Description Angel was caught by the MOLIGPY! He was put in prison by Moligpy. The prison is ...
- hdu1495(bfs)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 题意:有三个杯子,开始时第一个杯子装满水(体积为a),倒来倒去,得到其中2个杯里的水的体积都为a ...
- 非常可乐(杭电hdu1495)bfs
非常可乐 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- POJ 3278 经典BFS
进一步了解了bfs; 题意:给你n,然后用+,-,*三种运算使n变成k; 漏洞:在算出新的数字之后,一定要判边界,否则RE,而且在每一步后面都得加判断是否等于K,如果是即刻退出,否则WA,判这个的时候 ...
- POJ 3369 Meteor Shower (BFS,水题)
题意:给定 n 个炸弹的坐标和爆炸时间,问你能不能逃出去.如果能输出最短时间. 析:其实这个题并不难,只是当时没读懂,后来读懂后,很容易就AC了. 主要思路是这样的,先标记所有的炸弹的位置,和时间,在 ...
随机推荐
- 细说HTML元素的隐藏和显示
CSS文档对HTML的显示和隐藏有2个属性可供选择: 1.display 2.visiblity 这2个有什么区别呢? display: display版本:CSS1/CSS2 兼容性:IE4+ NS ...
- Mysql 监视工具
对于开发人员来说,最头大的莫过于 ,你本地没事,线上 错误日志一堆. 尤其是数据库通信那一层.SqlServer 有 sql profile 用来监视对应的server上的通信日志,参数 命令等信息. ...
- TaskController.java 20160712
package main.java.com.zte.controller.system; import java.io.PrintWriter; import java.util.ArrayList; ...
- Javascript中的数据类型知多少
JavaScript 是一种弱类型或者说动态语言.这意味着你不用提前声明变量的类型,在程序运行过程中,类型会被自动确定.这也意味着你可以使用同一个变量保存不同类型的数据 根据ECMAScript 5. ...
- PHP-数据库永久连接
以下为PHP官网上对数据库永久连接做的解释: 永久的数据库连接是指在脚本结束运行时不关闭的连接.当收到一个永久连接的请求时.PHP 将检查是否已经存在一个(前面已经开启的)相同的永久连接.如果存在,将 ...
- Numpy库应用实例——GPS定位
背景介绍 定位系统 GPS全球定位系统(Global Positioning System)以GPS系统为例介绍卫星定位的计算方法 GPS定位的基本原理 GPS定位的基本原理是根据高速运动卫星的 ...
- Squid调试和故障处理
http://blog.zhdata.com/tag/squid第16章 调试和故障处理 16.1 一些通用问题 在讨论通用debug前,我先提起一些经常发生的问题. 16.1.1 “Failed t ...
- ASP中页面之间传递值的几种方式
ASP.NET页面之间传递值的几种方式 页面传值是学习asp.net初期都会面临的一个问题,总的来说有页面传值.存储对象传值.ajax.类.model.表单等.但是一般来说,常用的较简单有QueryS ...
- Jmete ----r默认报告优化
转自:http://www.cnblogs.com/puresoul/p/5053035.html 一.本文目的: 之前写了两篇文章搭建持续集成接口测试平台(Jenkins+Ant+Jmeter)和A ...
- 使用NuGet发布自己的.NET NuGet 包( .NET Standard & Windows)
发布自己的nuget包 STEP 1:获取API Key 首先,你需要到NuGet上注册一个新的账号,然后在My Account页面,获取一个API Key,或者是自建服务器上生成一个API Key( ...