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

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

    DBMS_SUPPORT包从Oracle7.2引入,主要功能用以提供更完整的用户session跟踪信息,这个包可以通过运行 dbmssupp.sql 和 prvtsupp.plb 两个脚本来创建.该脚 ...

  2. D.E.Shaw——高频统计套利交易获利41亿美元

    黑科技,还是要提 D.E.Shaw Research 这个奇异的存在. 要讲这个黑科技,我们可能要扯远一点,先讲讲 D.E. Shaw 这个人是怎么学术赚钱通吃,成为彻底的人生大赢家的. D.E.Sh ...

  3. s3对象存储

    bkstorages 模块帮助你在蓝鲸应用中使用多种文件存储服务作为后端,用于加速静态资源,管理用户上传文件. 自定静态文件 storage 如果通过修改配置文件满足不了你的需求,你随时可以通过继承 ...

  4. Mysql中datetime和timestamp区别

    DATETIME日期和时间的组合.支持的范围是'1000-01-01 00:00:00'到'9999-12-31 23:59:59'.MySQL以'YYYY-MM-DD HH:MM:SS'格式显示DA ...

  5. 【代码片段】Python发送带图片的邮件

    # coding=utf-8 import smtplib from email.mime.text import MIMEText from email.mime.multipart import ...

  6. 7.2 Models -- Defining Models

    一.概述 1. 模型是一个类,它定义了你呈现给用户的数据的属性和行为.用户希望如果他们离开你的应用程序,并返回后(或如果他们刷新页面)看到的任何东西应该被一个model代表. 2. 确保在ember. ...

  7. OAuth 白话简明教程 4.刷新 Access Token

    转自:http://www.cftea.com/c/2016/11/6705.asp OAuth 白话简明教程 1.简述 OAuth 白话简明教程 2.授权码模式(Authorization Code ...

  8. ng-深度学习-课程笔记-2: 神经网络中的逻辑回归(Week2)

    1 二分类( Binary Classification ) 逻辑回归是一个二分类算法.下面是一个二分类的例子,输入一张图片,判断是不是猫. 输入x是64*64*3的像素矩阵,n或者nx代表特征x的数 ...

  9. 【MDCC 2015】开源选型之Android三大图片缓存原理、特性对比

    摘要:这是快的打车移动端架构师.Android 开源项目源码解析codeKK发起人 吴更新(@Trinea)在MDCC上分享的内容,从总体设计和原理上对几个图片缓存进行对比,没用到它们的朋友也可以了解 ...

  10. HBase相关概念

    1.Row Key 基本原则是:(1).由于读取数据只能依靠RowKey,所以应把经常使用到的字段作为行键{如手机号+时间戳拼接的字符串} (2).RowKey长度越短越好,最好不要超过16个字节.从 ...