博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu1495(经典bfs,平分水问题)
阅读量:7110 次
发布时间:2019-06-28

本文共 3996 字,大约阅读时间需要 13 分钟。

思路:搜索题,第一次做这种类型的题目吧,一开始表示不怎么明白题意所说的东东。其实就是要你判断可乐能不能被平分........

有六种状态,从a瓶到b瓶,a-->c

b-->a     b-->c

c-->a     c-->b

然后每种状态里面又分两种不同情况,可以将此瓶的水全部清空,不能清空......

然后广搜就可以了........

#include
#include
#include
#include
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
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;}

 

转载地址:http://rclhl.baihongyu.com/

你可能感兴趣的文章
[Angular] Angular ngSwitch Core Directive In Detail
查看>>
JSON Web Token(JWT)使用步骤说明
查看>>
思绪:常想一二
查看>>
WPF - Group分组对ListBox等列表样式的约束
查看>>
getpwuid和getpwnam的用法
查看>>
C语言文件操作解析(一)
查看>>
matlab练习程序(Floyd–Steinberg dithering)
查看>>
Android之Handler用法总结
查看>>
《敏捷个人》周刊 第3期 (可下载)
查看>>
XPath and TXmlDocument
查看>>
JQ集合
查看>>
bootstrip可视化布局
查看>>
企业架构如何实施的简介(深度好文)
查看>>
python 一些基本操作
查看>>
Linux 的启动流程(转)
查看>>
【45】运用成员函数模版接受所有兼容类型
查看>>
flex graphiclar symbol的不同比例尺切换
查看>>
linux img文件压缩及解压
查看>>
当远程桌面到Windows终端服务器,出现终端服务器超出了最大允许连接数,怎么办...
查看>>
S3C2410 实验三——块拷贝、字拷贝(寄存器的理解)
查看>>