题意:推箱子游戏

代码写错居然卡内存!!

搞了两天了

 #include <iostream>
#include <cstdio>
#include <cstring>
#include <queue> using namespace std;
char s[][];
int d[][]={,,,,-,,,-};
int n,m,tt;
struct node
{
int x,y;
};
struct all
{
node a[];
int t;
}st,ed;
bool vis[][][][][][][][]; bool aim[][];
bool ok(all e)
{
for(int i=;i<;i++)
{
if(!aim[e.a[i].x][e.a[i].y])
{
return false;
}
}
return true;
}
queue<all> q;
void bfs()
{
all now,next;
memset(aim,false,sizeof(aim));
memset(vis,false,sizeof(vis));
while(!q.empty()) q.pop();
q.push(st);
for(int i=;i<;i++)
aim[ed.a[i].x][ed.a[i].y]=true;
while(!q.empty())
{
now=q.front();
q.pop();
if(ok(now))
{
printf("%d\n",now.t);
return;
}
//printf("%d %d %d %d %d %d %d %d %d\n",now.a[3].x,now.a[3].y,now.a[0].x,now.a[0].y,now.a[1].x,now.a[1].y,now.a[2].x,now.a[2].y,now.t);
if(vis[now.a[].x][now.a[].y][now.a[].x][now.a[].y][now.a[].x][now.a[].y][now.a[].x][now.a[].y])
continue;
vis[now.a[].x][now.a[].y][now.a[].x][now.a[].y][now.a[].x][now.a[].y][now.a[].x][now.a[].y]=true;
for(int i=;i<;i++)
{
int nx=now.a[].x+d[i][]; //人的移动
int ny=now.a[].y+d[i][];
if(s[nx][ny]=='#'||nx<||nx>=n||ny<||ny>=m) continue;
int j;
for(j=;j<;j++) //人撞到箱子
{
if(nx==now.a[j].x&&ny==now.a[j].y)
{
break;
}
}
if(j>=) //并没有推到箱子
{
next=now;
next.a[].x=nx,next.a[].y=ny;
next.t++;
q.push(next);
}
else //推到箱子
{
nx+=d[i][],ny+=d[i][]; //箱子移动
if(nx<||nx>=n||ny<||ny>=m||s[nx][ny]=='#') continue;
int k=;
for(k=;k<;k++)
{
if(nx==now.a[k].x&&ny==now.a[k].y)
{
break;
}
}
if(k>=) //箱子旁边并没有其他箱子
{
next=now;
next.a[].x=nx-d[i][],next.a[].y=ny-d[i][]; //人的坐标
next.a[j].x=nx,next.a[j].y=ny; //箱子坐标
next.t++;
q.push(next);
}
}
}
}
printf("-1\n");
}
int main()
{
int i,j,k;
#ifndef ONLINE_JUDGE
freopen("1.in","r",stdin);
#endif
while(scanf("%d%d",&n,&m)!=EOF)
{
int cnt1=,cnt2=;
for(i=;i<n;i++)
{
scanf("%s",s[i]);
for(j=;j<m;j++)
{
if(s[i][j]=='X')
{
st.a[].x=i,st.a[].y=j;
}
else if(s[i][j]=='*')
{
st.a[cnt1].x=i,st.a[cnt1++].y=j;
}
else if(s[i][j]=='@')
{
ed.a[cnt2].x=i,ed.a[cnt2++].y=j;
}
if(s[i][j]!='#') s[i][j]='.';
}
}
st.t=;
bfs();
}
return ;
}

hdu 1732 bfs的更多相关文章

  1. hdu 4531 bfs(略难)

    题目链接:点我 第一次不太清楚怎么判重,现在懂了,等下次再做 /* *HDU 4531 *BFS *注意判重 */ #include <stdio.h> #include <stri ...

  2. hdu 1732 Push Box

    http://acm.hdu.edu.cn/showproblem.php?pid=1732 推箱子和游戏规则一样. #include <cstdio> #include <cstr ...

  3. HDU 2822 (BFS+优先队列)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2822 题目大意:X消耗0,.消耗1, 求起点到终点最短消耗 解题思路: 每层BFS的结点,优先级不同 ...

  4. HDU 1180 (BFS搜索)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1180 题目大意:迷宫中有一堆楼梯,楼梯横竖变化.这些楼梯在奇数时间会变成相反状态,通过楼梯会顺便到达 ...

  5. HDU 2531 (BFS搜索)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2531 题目大意: 你的身体占据多个点.每次移动全部的点,不能撞到障碍点,问撞到目标点块(多个点)的最 ...

  6. HDU 5025 (BFS+记忆化状压搜索)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5025 题目大意: 迷宫中孙悟空救唐僧,可以走回头路.必须收集完钥匙,且必须按顺序收集.迷宫中还有蛇, ...

  7. HDU 1429 (BFS+记忆化状压搜索)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1429 题目大意:最短时间内出迷宫,可以走回头路,迷宫内有不同的门,对应不同的钥匙. 解题思路: 要是 ...

  8. HDU 1026 (BFS搜索+优先队列+记录方案)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1026 题目大意:最短时间内出迷宫.迷宫里要杀怪,每个怪有一定HP,也就是说要耗一定时.输出方案. 解 ...

  9. HDU 1312 (BFS搜索模板题)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1312 题目大意:问迷宫中有多少个点被访问. 解题思路: DFS肯定能水过去的.这里就拍了一下BFS. ...

随机推荐

  1. FPGA设计方法检查表

    -----------------------摘自<FPGA软件测试与评价技术> 中国电子信息产业发展研究院 | 编著------------------------------- 文本格 ...

  2. verilog中wire与reg类型的区别

    每次写verilog代码时都会考虑把一个变量是设置为wire类型还是reg类型,因此把网上找到的一些关于这方面的资料整理了一下,方便以后查找. wire表示直通,即只要输入有变化,输出马上无条件地反映 ...

  3. python 结构化数据解析

    # -*- coding: utf-8 -*- # @Time : 2018/8/31 14:32 # @Author : cxa # @File : glomtest.py # @Software: ...

  4. MVVM模式的命令绑定

    命令绑定要达到的效果 命令绑定要关注的核心就是两个方面的问题,命令能否执行和命令怎么执行.也就是说当View中的一个Button绑定了ViewModel中一个命令后,什么时候这个Button是可用的, ...

  5. ETL利器Kettle实战应用解析系列二

    本系列文章主要索引如下: 一.ETL利器Kettle实战应用解析系列一[Kettle使用介绍] 二.ETL利器Kettle实战应用解析系列二 [应用场景和实战DEMO下载] 三.ETL利器Kettle ...

  6. python网络编程--RabbitMQ

    一:RabbitMQ介绍 RabbitMQ是AMPQ(高级消息协议队列)的标准实现.也就是说是一种消息队列. 二:RabbitMQ和线程进程queue区别 线程queue:不能跨进程,只能用于多个线程 ...

  7. 从源码层次分析asterisk如何产生呼叫

    老规矩,看别人是怎么搞的 http://blog.chinaunix.net/uid-14723273-id-1739552.html over...

  8. 进程同步——哲学家进餐问题Java实现

    哲学家就餐问题是1965年由Dijkstra提出的一种线程同步的问题. 问题描述:一圆桌前坐着5位哲学家,两个人中间有一只筷子,桌子中央有面条.哲学家思考问题,当饿了的时候拿起左右两只筷子吃饭,必须拿 ...

  9. Centos之帮助命令

    帮助命令man  (manual) 比如我们可以看下man命令的解释 [root@localhost ~]# man man MAN(1)                               ...

  10. hmm学习笔记(二)

    学习hmm近一周的时间,做个总结. 参考  李航的<统计学习方法>第9章,第10章 本文包含: 1.hmm模型 2.前向后向算法 3.Baum-Welch算法 4.维特比算法 1.hmm模 ...