UVA1601 状态搜索
很有意思的一道题,就是迷宫问题的增强版。但是细节很多,有一个技巧就是把每个可以走的位置编号方便状态判重。
AC代码:
#include<cstdio>
#include<cstring>
#include<queue>
#include<iostream>
using namespace std;
const int maxs=20;
const int maxn=150;
const int dx[]={1,-1, 0, 0, 0};
const int dy[]={0, 0, 1,-1, 0};
int s[3],t[3];
int deg[maxn], G[maxn][5];
int d[maxn][maxn][maxn]; //记录步数
struct node //记录状态
{
int a,b,c;
node(int x,int y,int z):a(x),b(y),c(z){}
};
bool conflict(int a,int b,int a1,int b1)
{
return a1==b1||(a1==b&&b1==a); //判断是否移动到同一个格子或者在一步中互换了位置
}
int bfs()
{
queue<node>q;
memset(d,-1,sizeof(d));
d[s[0]][s[1]][s[2]]=0;
q.push(node(s[0],s[1],s[2]));
while(!q.empty())
{
node u=q.front(); q.pop();
int a=u.a,b=u.b,c=u.c;
if(a==t[0]&&b==t[1]&&c==t[2]) return d[a][b][c];
//开始移动,移动时需要判断是否移动到同一个位置
for(int i=0;i<deg[a];++i)
{
int a1=G[a][i];
for(int j=0;j<deg[b];++j)
{
int b1=G[b][j];
if(conflict(a,b,a1,b1)) continue;
for(int k=0;k<deg[c];++k)
{
int c1=G[c][k];
if(conflict(a,c,a1,c1)) continue;
if(conflict(b,c,b1,c1)) continue;
if(d[a1][b1][c1]!=-1) continue;
d[a1][b1][c1]=d[a][b][c]+1;
q.push(node(a1,b1,c1));
}
}
}
}
}
int main()
{
int w, h, n;
while(scanf("%d%d%d\n",&w,&h,&n)==3&&w!=0)
{
char res[maxs][maxs];
for(int i=0;i<h;++i) fgets(res[i],20,stdin);
int cnt=0;
int x[maxn],y[maxn],id[maxs][maxs];
//给每个空格编号,很好的技巧,可以提高状态转换、判重的效率
for(int i=0;i<h;++i)
for(int j=0;j<w;++j)
{
if(res[i][j]!='#')
{
x[cnt]=i;y[cnt]=j;id[i][j]=cnt;
if(islower(res[i][j])) s[res[i][j]-'a']=cnt;
else if(isupper(res[i][j])) t[res[i][j]-'A']=cnt;
++cnt;
}
}
for(int i=0;i<cnt;++i)
{
deg[i]=0;
for(int dir=0;dir<5;++dir)
{
int px=x[i]+dx[dir],py=y[i]+dy[dir];
if(px<0||px>=h||py<0&&py>=w) continue;
if(res[px][py]!='#') G[i][deg[i]++]=id[px][py]; //当前空格的临近空格
}
}
//为了简化代码,给少于三个鬼的情况增加到三个点,新增的点被处理为无法移动。
if(n<=2) {deg[cnt] = 1; G[cnt][0] = cnt; s[2]=t[2]=cnt++;}
if(n<=1) {deg[cnt] = 1; G[cnt][0] = cnt; s[1]=t[1]=cnt++;}
printf("%d\n",bfs());
}
return 0;
}
如有不当之处欢迎指出!!
UVA1601 状态搜索的更多相关文章
- ACM/ICPC 2018亚洲区预选赛北京赛站网络赛 A、Saving Tang Monk II 【状态搜索】
任意门:http://hihocoder.com/problemset/problem/1828 Saving Tang Monk II 时间限制:1000ms 单点时限:1000ms 内存限制:25 ...
- UVALive 6255 Kingdoms --状态搜索
题意:n个国家,给出国家间相互的债务关系,每个国家如果债务>收入就要破产,破产后该国的所有债务关系全部清除,第一个破产的国家不同有可能造成最后的没破产的国家的不同,问哪些国家有可能成为独自存活的 ...
- 用BFS和DFS解决圆盘状态搜索问题
人工智能课程的实验(我的解法其实更像是算法课程的实验) 用到的算法:深度优先搜索.宽度优先搜索(状态扩展的不同策略) 数据结构:表示状态的结构体.多维数组 (可能是最近做算法竞赛题的影响,这次并不像以 ...
- Oj 24260: Lilypad Pond (神奇广搜题,状态搜索)
题目 为了让奶牛们娱乐和锻炼,约翰建造了一个美丽的池塘.这个池塘是矩形的,可以分成M×N个方格.一些格子是坚固得令人惊讶的莲花,还有一些是岩石,其余的只是美丽,纯净,湛蓝的水.贝西正在练习芭蕾舞,她站 ...
- BFS + 状态搜索
题目 题意 给一个100x100的迷宫,'.'表示路面,'S'表示起点,'T'表示终点:'#'表示毒气区,进入毒气区必须要消耗一个氧气:'B'表示氧气区,每次进入自动获得一个氧气,可反复进入从而获得多 ...
- laravel使用when搜索遇到状态参数(有0的状态)的坑
今天,使用when()方法写活动列表的接口,有两个状态搜索,都有0这个状态,当传参为0时when()就失效了... 反反复复的验证参数,传参确实是0和1啊...百思不得其解~~~后面仔细想想when( ...
- [学习笔记]搜索——模拟与dp的结合
搜索: 一种基础的算法. 考察常见于NOIP 但是高级的搜索算法可能还会在省选出现. 50%以上的暴力都可以用搜索直接枚举来写. 但是,当数据规模不是很大的时候,搜索也可能成为正解. (比如剪枝PK状 ...
- Button Bashing(搜索)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx8AAAI2CAIAAAC+EqK4AAAgAElEQVR4nOydf0BT9f7/37fS423mWn
- POJ2676 (数独问题 + DLX + 状态优化顺序)
(1)最简单的最是去暴力DFS搜索答案 , 很容易想到 , 每行每列的方式去搜索 , 不过效率是真的不行;但这个还是给出代码 ,毕竟打了也不容易呀! #include<cstdio> #i ...
随机推荐
- Linux实践篇--crontab定时任务
原文出处:http://www.cnblogs.com/tracy/archive/2011/12/27/2303788.html.感谢作者的无私分享 一. Crontab 介绍 ...
- Linux系统中调用短信猫发送短信(笔记)
1, 拷贝底层串口依赖的librxtxSerial.so到JDK安装路径cp librxtxSerial.so /usr/java/{0}/jre/lib/{1} # {0}: JDK的基础目录,例如 ...
- android webview加载网络连接
webview = (WebView) findViewById(R.id.webview); WebSettings webSettings = webview.getSettings(); //设 ...
- 【转】shell学习笔记(三)——引用变量、内部变量、条件测试、字符串比较、整数比较等
1.env显示当前的环境变量 2.PS1='[\u@\h \w \A] \$' 可以设置bash的命令与提示符. 3.echo $$ 显示当前bash的PID号 4.echo $?显示上一条指令的回传 ...
- struts2.xml的配置问题
1.<package namespace="/"></package> namespace决定访问action的路径: 如果省略,将代表任意路径: 2.&l ...
- 关系类型字段 -- Django从入门到精通系列教程
该系列教程系个人原创,并完整发布在个人官网刘江的博客和教程 所有转载本文者,需在顶部显著位置注明原作者及www.liujiangblog.com官网地址. Python及Django学习QQ群:453 ...
- 换行符\n和回车符\r
问题始于社区的一个帖子,楼主的问题如下: “在c语言中,对一个不知道大小的文件进行读操作,我用fread()将文件的内容先放到一个缓存区,然后将缓存区中的内容打印出来, 缓存区中的内容和文件中的内容不 ...
- 不干胶打印机 www.bgjdyj.com
不干胶打印机如何保养 不干胶打印机专卖网根据多年的维修经验总结了以下几种保养不干胶打印机的方法: 1.不干胶打印机打印机标签纸不能搁置太长时间,第一容易起静电.第二容易起灰尘2.不干胶打印机的打印头最 ...
- 【原创】源码角度分析Android的消息机制系列(五)——Looper的工作原理
ι 版权声明:本文为博主原创文章,未经博主允许不得转载. Looper在Android的消息机制中就是用来进行消息循环的.它会不停地循环,去MessageQueue中查看是否有新消息,如果有消息就立刻 ...
- hexo建立github,gitcafe博客并实时同步的要点
把hexo博客的源码和生成的页面实时同步到github和gitcafe. 用搜索引擎搜索"github 博客"等关键字会出现大量很好的文章教小白一步步搭建.我这里列出一些关键点,希 ...