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

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

    通过阅读这篇文章对内存的处理以及栈的扩容有了新的认识,我们在生产环境中也遇到了内存使用量超大的情况,现在怀疑也可能是由于栈扩容导致的 很好的一片文章: 推送在外卖订餐中扮演着重要的角色,为商家实时接单 ...

  2. SQL---->mySQl数据库1------数据库的增删改查备份恢复

    1.在终端输入:mysql -uroot -p      然后输入密码,进入客户端 2.输入:\s 3.创建数据库 3.1创建字符集是utf-8的数据库 3.2创建带校验规则的数据库,校验规则可以在a ...

  3. 详解spring boot mybatis全注解化

    本文重点介绍spring boot mybatis 注解化的实例代码 1.pom.xml //引入mybatis <dependency> <groupId>org.mybat ...

  4. Maven 的聚合(多模块)和 Parent 继承

    2017年06月26日 21:16:57 Maven 的聚合(多模块)和 Parent 继承 - 偶尔记一下 - CSDN博客 https://blog.csdn.net/isea533/articl ...

  5. Spring 依赖注入 基于构造函数、设值函数、内部Beans、集合注入

    Spring 基于构造函数的依赖注入_w3cschool https://www.w3cschool.cn/wkspring/t7n41mm7.html Spring 基于构造函数的依赖注入 当容器调 ...

  6. MySQL插入性能优化(转)

    原文:http://tech.uc.cn/?p=634 对于一些数据量较大的系统,数据库面临的问题除了查询效率低下,还有就是数据入库时间长.特别像报表系统,每天花费在数据导入上的时间可能会长达几个小时 ...

  7. shell 变量定义技巧总结

    可以多学习和模仿操作系统自带的/etc/init.d/functions函数库脚本的定义思路,多学习Linux系统脚本中的定义,有经验的读者最终应形成一套适合自己的规范和习惯. (1)变量名及变量内容 ...

  8. django基础之Ajax、分页、cookie与session

    目录: Ajax之json Ajax简介 jquery实现的ajax js实现的ajax django分页器 COOKIE与SESSION 一.Ajax之json 1.什么是json? 定义: JSO ...

  9. STL学习笔记--各种容器的运用时机

    如何选择最佳的容器类别? 缺省情况下应该使用vector.vector的内部结构简单,并允许随机存取,所以数据的存取十分方便灵活,数据的处理也够快. 如果经常要在序列的头部和尾部安插和移除元素,应采用 ...

  10. Java StringBuffer 和 StringBuilder 类

    当对字符串进行修改的时候,需要使用 StringBuffer 和 StringBuilder 类. 和 String 类不同的是,StringBuffer 和 StringBuilder 类的对象能够 ...