您的位置:首页 > 其它

hdu1495~广搜

2016-05-25 21:32 330 查看
思路:

其实就是要判断可乐能不能被平分……..

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

b–>a b–>c

c–>a c–>b

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

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

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>

using namespace std;

int vist[105][105][105];
int a, b, c;
struct node
{
int a, b, c;
int step;
}s[105];
int sum = 0;
int bfs();
int main()
{
while (scanf_s("%d %d %d", &a, &b, &c) != EOF && (a + b + c))
{
if (a % 2 == 1)
{
printf("NO\n");
continue;
}
int ans = bfs();
if (ans >= 0)
printf("%d\n", ans);
else
printf("NO\n");
}
return 0;
}
int  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))   //如果平分就返回步数
{
return p1.step;
}
node p2;
if (p1.a != 0)
{
if (p1.a > b - p1.b)//a往b倒,a还没清空
{
p2.a = p1.a - (b - p1.b);
p2.b = b;
p2.c = p1.c;
p2.step = p1.step + 1;
}
else//a往b倒,a清空
{
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[][][]标记是否走过,走过标记为1
{
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);
}
}
}
return -1;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: