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

题目分析:这道题出的比较人性,输入的时候便是将四周的墙用二进制数表示好了,其实这样减轻了做题人的负担。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. c# 调用声音文件

    一.使用C#自带的SoundPlayer using System.Media; SoundPlayer sound = new SoundPlayer("声音.wav"); so ...

  2. 导出Excel过程中遇到的问题java.lang.NoClassDefFoundError: org/apache/xmlbeans/XmlException

    尝试实现java导出功能时遇到如下报错: org.apache.jasper.JasperException: javax.servlet.ServletException: java.lang.No ...

  3. Oracle Schema Objects——伪列ROWID Pseudocolumn(ROWNUM、ROWID)

    Oracle Schema Objects Oracle Schema Objects——Tables——Oracle Data Types Oracle伪列 在Oracle数据库之中为了实现完整的关 ...

  4. 系统中同时有 python2和 python3,怎么让 ipython 选择不同的版本启动?

    已经安装的情况下: > which ipython /usr/local/bin/ipython > cat /usr/local/bin/ipython  #!/usr/local/op ...

  5. [SQL] 让特定的数据 排在最前

    MYSQL目前常用的两种方法,如下: 让值为"张三" 的数据排在最前. -- 方法一 end asc -- 方法二 select * from tableName where co ...

  6. C# WinForm实现任务栏程序图标闪烁

    相信大家在用QQ的时候都会知道,你打开了QQ聊天窗口,如果窗口不是当前激活的窗口的话,收到QQ消息时,任务栏(不是托盘图标)上的图标会闪一下变成黄色(Win7默认主题下),用以通知用户有消息进来了,之 ...

  7. Logback配置讲解

    复制文件并粘贴到项目下: logback.xml: <?xml version="1.0" encoding="UTF-8"?> <confi ...

  8. Linux常用命令【总结】

    Linux命令中文版详解:https://linuxtools-rst.readthedocs.io/zh_CN/latest/tool/index.html Linux系统,我用过的有centos和 ...

  9. cocos-lua基础学习(四)quick层封装后的目录结构

    命名空间 cc cocos2d核心类 ccb cocosbuilder扩展 ccs cocostudio扩展 cocos2d目录结构 bitExtend.lua cocos2d.lua cocos2d ...

  10. 跨域nginx,CORS

    浏览器的同源策略是浏览器上为安全性考虑实施的非常重要的安全策略.从一个域上加载的脚本不允许访问另外一个域的文档属性.举个例子:比如一个恶意网站的页面通过iframe嵌入了银行的登录页面(二者不同源), ...