题目大意:走迷宫,遇到墙时可以推着墙走,但墙后还是墙时便不能推。求出一条任意的最短路径。

题目分析:这道题出的比较人性,输入的时候便是将四周的墙用二进制数表示好了,其实这样减轻了做题人的负担。IDA*,当到最近的一个出口的距离加上当前层数cur都比maxd大时,则剪枝。不过,值得注意的是:当推着墙走的时候,涉及到3个格子周围的墙的变化(在边界除外)。

代码如下:

# include<iostream>
# include<cstdio>
# include<cmath>
# include<vector>
# include<cstring>
# include<algorithm>
using namespace std; struct XY
{
int x,y;
XY(int _x,int _y):x(_x),y(_y){}
};
vector<XY>xy;
int mp[4][6],sx,sy;
int d[4][2]={{0,-1},{-1,0},{0,1},{1,0}};
int dd[4]={2,3,0,1};
string pd="WNES",ans; void f()
{
xy.clear();
for(int i=0;i<6;++i){
if((mp[0][i]&2)==0)
xy.push_back(XY(0,i));
if((mp[3][i]&8)==0)
xy.push_back(XY(3,i));
}
for(int i=0;i<4;++i){
if((mp[i][0]&1)==0)
xy.push_back(XY(i,0));
if((mp[i][5]&4)==0)
xy.push_back(XY(i,5));
}
} bool dfs(int cur,int maxd,int x,int y,string path)
{
if(cur==maxd){
if(x==0&&((mp[x][y]&2)==0)){
ans=path+'N';
return true;
}
if(x==3&&((mp[x][y]&8)==0)){
ans=path+'S';
return true;
}
if(y==0&&((mp[x][y]&1)==0)){
ans=path+'W';
return true;
}
if(y==5&&((mp[x][y]&4)==0)){
ans=path+'E';
return true;
}
return false;
} f();
int minn=10000,l=xy.size();
for(int i=0;i<l;++i)
minn=min(minn,abs(x-xy[i].x)+abs(y-xy[i].y));
if(cur+minn>maxd)
return false; for(int i=0;i<4;++i){
int nx=x+d[i][0],ny=y+d[i][1];
if(nx<0||nx>3||ny<0||ny>5)
continue;
if(mp[x][y]&(1<<i)){
if(mp[nx][ny]&(1<<i))
continue;
mp[x][y]^=(1<<i);
mp[nx][ny]^=(1<<dd[i]);
mp[nx][ny]^=(1<<i);
int nnx=nx+d[i][0],nny=ny+d[i][1];
if(nnx>=0&&nnx<4&&nny>=0&&nny<6)
mp[nnx][nny]^=(1<<dd[i]);
if(dfs(cur+1,maxd,nx,ny,path+pd[i]))
return true;
mp[nx][ny]^=(1<<i);
mp[nx][ny]^=(1<<dd[i]);
mp[x][y]^=(1<<i);
if(nnx>=0&&nnx<4&&nny>=0&&nny<6)
mp[nnx][nny]^=(1<<dd[i]);
}else{
if(dfs(cur+1,maxd,nx,ny,path+pd[i]))
return true;
}
}
return false;
} int main()
{
//freopen("UVA-10384 The Wall Pushers.txt","r",stdin);
while(scanf("%d%d",&sy,&sx)&&(sx+sy))
{
--sx,--sy;
for(int i=0;i<4;++i)
for(int j=0;j<6;++j)
scanf("%d",&mp[i][j]);
for(int maxd=0;;++maxd){
if(dfs(0,maxd,sx,sy,"")){
cout<<ans<<endl;
break;
}
}
}
return 0;
}

  

UVA-10384 The Wall Pushers (IDA*)的更多相关文章

  1. UVA - 10384 The Wall Pusher(推门游戏)(IDA*)

    题意:从起点出发,可向东南西北4个方向走,如果前面没有墙则可走:如果前面只有一堵墙,则可将墙向前推一格,其余情况不可推动,且不能推动游戏区域边界上的墙.问走出迷宫的最少步数,输出任意一个移动序列. 分 ...

  2. UVa 10384 - The Wall Pushers

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  3. 【UVa】1374 Power Calculus(IDA*)

    题目 题目     分析 IDA*大法好,抄了lrj代码.     代码 #include <cstdio> #include <cstring> #include <a ...

  4. uva 1153 顾客是上帝(贪心)

    uva 1153 顾客是上帝(贪心) 有n个工作,已知每个工作需要的时间q[i]和截止时间d[i](必须在此前完成),最多能完成多少个工作?工作只能串行完成,第一项任务开始的时间不早于时刻0. 这道题 ...

  5. UVA10384-The Wall Pushers(迭代加深搜索)

    Problem UVA10384-The Wall Pushers Accept: 199   Submit: 1546Time Limit: 10000 mSec Problem Descripti ...

  6. Booksort POJ - 3460 (IDA*)

    Description The Leiden University Library has millions of books. When a student wants to borrow a ce ...

  7. 人类即将进入互联网梦境时代(IDA)

    在电影<盗梦空间>中,男主角科布和妻子在梦境中生活了50年,从楼宇.商铺.到河流浅滩.一草一木.这两位造梦师用意念建造了属于自己的梦境空间.你或许并不会想到,在不久未来,这看似科幻的情节将 ...

  8. UVA 1479 Graph and Queries (Treap)

    题意: 给一个无向图,再给一系列操作(以下3种),输出最后的平均查询结果. (1)D X 删除第x条边. (2)Q X k  查询与点X相连的连通分量中第k大的点的权值. (3)C X v  将点X的 ...

  9. UVa 210 并行程序模拟(deque)

    题意: 模拟n个程序运行 格式一共有5种:var = constant(赋值):print var(打印):lock:unlock:end, 上述5种语句分别需要t1.t2.t3.t4.t5单位时间 ...

随机推荐

  1. pta 习题集5-17 哥尼斯堡的“七桥问题”

    哥尼斯堡是位于普累格河上的一座城市,它包含两个岛屿及连接它们的七座桥,如下图所示. 可否走过这样的七座桥,而且每桥只走过一次?瑞士数学家欧拉(Leonhard Euler,1707-1783)最终解决 ...

  2. checkbox的name与JavaBean的交互时发现的一个现象

    一个页面: <form action="reg.jsp" method="post"> <ul> <li>算法选择</ ...

  3. 设计模式之——Decorator模式

    Decorator模式又叫装饰者模式,这种模式是为了满足Java开发的"面向扩展开放,面向修改闭源"的开发原则设计出来的. 在装饰者模式中,不修改源类的代码,却能修改源类中方法的功 ...

  4. [Python模块学习]用qrcode模块生成二维码

    转自:https://blog.csdn.net/jy692405180/article/details/65937077

  5. 阿里云centos7.2 安装mysql 6.5

    [root@111 ~]# uname -aLinux bxhs 3.10.0-327.22.2.el7.x86_64 #1 SMP Thu Jun 23 17:05:11 UTC 2016 x86_ ...

  6. Windows中杀死某个端口的进程

    最近写项目,总是出现端口被占用的问题,原来傻傻的把电脑重启一下,终于有一天受不了了,想要想办法解决.刚开始从网上找了好多教程,发现不行.开始自己尝试,终于,成功的将占用端口的进程杀掉.在此记录下过程( ...

  7. 求连续出现5次以上的值,并且取第5次所在id

    关键字:求连续出现5次以上的值,并且取第5次所在id 关键字:求在某列连续出现N次值的的数据,并且取第M次出现所在行 需求,求连续出现5次以上的值,并且取第5次所在id SQL SERVER: --测 ...

  8. MySQL创建索引命令

    MySQL索引类型 普通索引 创建索引的方式 -- 直接新建索引 CREATE INDEX indexName ON mytable(username(length)) -- 修改表结构新建索引 AL ...

  9. nmon 命令

    nmon 命令 用途 以交互方式显示本地系统统计信息并以记录方式记录系统统计信息. 语法 交互方式: nmon [ -h ] nmon [ -s < seconds >] [ -c < ...

  10. 手把手教你学node.js之一个简单的express应用

    一个简单的express应用 目标 建立一个 lesson1 项目,在其中编写代码.当在浏览器中访问 http://localhost:3000/ 时,输出 Hello World. 挑战 访问 ht ...