P4289 [HAOI2008]移动玩具(bfs)
双向bfs+状态压缩+记忆化搜索
双向bfs用于对bfs的优化,每次找到可扩展节点少的一边进行一次bfs,找到的第一个互相接触的点即为最短路径
矩阵范围仅4*4大小,我们容易想到用二进制数压缩其状态,利于求解。
既然转成二进制,大小又<2^17,那么可以再加数组进行记忆化
不要忘了起点终点相同时的特判qwq
#include<iostream>
#include<cstdio>
#include<queue>
#include<cstring>
using namespace std;
struct data{int zip,step;};
int ans,rec1[],rec2[]; //rec:记忆化用
queue <data> h[]; //分别代表从起点/终点开始的bfs队列
inline void check(int to,int p,data x){ //检查该点是否符合条件
if(rec1[to]!=-){
if(rec2[to]!=p) ans=rec1[to]+x.step+; //如果该点已被对面搜到,那么已经得出最优解
}else{
rec1[to]=x.step+,rec2[to]=p;
h[p].push((data){to,x.step+});
}
}
void output(int t){ //检查用,将10进制数转回4*4的二进制矩阵
cout<<"---\n";
int h[];
for(int k=t,i=;i>=;--i) h[i]=k&,k>>=;
for(int i=;i<;++i){
for(int j=i*;j<=i*+;++j) cout<<h[j];
cout<<endl;
}
cout<<"---\n";
}
inline void bfs(){
int p=(h[].size()>h[].size()),now=(h[p].front()).step; //找到可扩展节点少的一边,并且只扩展一层
while(!h[p].empty()){
data x=h[p].front();
if(x.step!=now||ans) break;
h[p].pop();
int k=,to;
for(int i=;i<;i<<=,++k){ //用二进制数表示转移过程
if(!(x.zip&i)) continue;
if(k%!=&&(!(x.zip&(i<<)))){ //向左
to=x.zip-i+(i<<);
check(to,p,x);
}
if(k%!=&&(!(x.zip&(i>>)))){ //向右
to=x.zip-i+(i>>);
check(to,p,x);
}
if(k>&&(!(x.zip&(i>>)))){ //向下
to=x.zip-i+(i>>);
check(to,p,x);
}
if(k<&&(!(x.zip&(i<<)))){ //向上
to=x.zip-i+(i<<);
check(to,p,x);
}
}
}
}
int main(){
memset(rec1,-,sizeof(rec1));
char q[]; int tot1=,tot2=;
for(int i=;i<=;++i){ //矩阵转成十进制数
cin>>q;
for(int j=;j<=;++j) tot1+=q[j]-,tot1<<=;
}tot1>>=; //注意最后要右移一位
h[].push((data){tot1,}); rec1[tot1]=; rec2[tot1]=;
for(int i=;i<=;++i){
cin>>q;
for(int j=;j<=;++j) tot2+=q[j]-,tot2<<=;
}tot2>>=;
h[].push((data){tot2,}); rec1[tot2]=; rec2[tot2]=;
while(!ans&&tot1!=tot2) bfs(); //注意特判
printf("%d",ans);
return ;
}
P4289 [HAOI2008]移动玩具(bfs)的更多相关文章
- 【BZOJ1054】[HAOI2008]移动玩具 BFS
[BZOJ1054][HAOI2008]移动玩具 Description 在一个4*4的方框内摆放了若干个相同的玩具,某人想将这些玩具重新摆放成为他心中理想的状态,规定移动 时只能将玩具向上下左右四个 ...
- [BZOJ1054][HAOI2008]移动玩具 bfs+hash
1054: [HAOI2008]移动玩具 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2432 Solved: 1355[Submit][Stat ...
- bzoj 1054: [HAOI2008]移动玩具 bfs
1054: [HAOI2008]移动玩具 Time Limit: 10 Sec Memory Limit: 162 MB[Submit][Status][Discuss] Description 在 ...
- P4289 [HAOI2008]移动玩具
传送门 广搜 4*4 的方阵只有 0 和 1 显然可以状态压缩 (如样例的开始状态压缩后就是1111000011100010) 为了加快速度用了双向广搜(顺便学了一下双向广搜) 双向广搜顾名思义 就是 ...
- luogu P4289 [HAOI2008]移动玩具
传送门 这道题可以二进制记录状态搜索 也可以做以下考虑 若一个棋子要移动到另一个位置上去,则步数为两点的曼哈顿距离(横坐标差的绝对值+纵坐标差的绝对值),因为假设路径上有其他的棋子,可以通过移动其他棋 ...
- P4289 【一本通提高篇广搜的优化技巧】[HAOI2008]移动玩具
[HAOI2008]移动玩具 题目描述 在一个 4 × 4 4\times4 4×4 的方框内摆放了若干个相同的玩具,某人想将这些玩具重新摆放成为他心中理想的状态,规定移动时只能将玩具向上下左右四个方 ...
- bzoj1054: [HAOI2008]移动玩具
hash+bfs:要注意特殊情况.(似乎连sort.lower_bound都不用数据小直接判重了... #include<cstdio> #include<cstring> # ...
- BZOJ 1054 [HAOI2008]移动玩具
1054: [HAOI2008]移动玩具 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1388 Solved: 764[Submit][Statu ...
- 1054: [HAOI2008]移动玩具
1054: [HAOI2008]移动玩具 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1272 Solved: 690[Submit][Statu ...
随机推荐
- Docker 学习应用篇之二: Docker的介绍和安装
之前说过Docker的好处,Docker可以集装箱化的部署应用程序.那么Docker是通过什么实现的呢.要理解Docker内部构建,需要先理解Docker的四种部件 1)images:镜像,docke ...
- poj2778 DNA Sequence【AC自动机】【矩阵快速幂】
DNA Sequence Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 19991 Accepted: 7603 Des ...
- TOP100summit:【分享实录】Twitter 新一代实时计算平台Heron
本篇文章内容来自2016年TOP100summit Twitter technical lead for Heron Maosong Fu 的案例分享. 编辑:Cynthia Maosong Fu:T ...
- phpstrom 配置xdebug在vagrant上调试
参数 linux system : centos6. vagrant: PHP: phpstrom:2017.2 步骤1: 安装xdebug扩展(已安装可跳过步骤1),首先去 xdebug官方下载扩展 ...
- ubuntu 12.10上安装tftpd-hpa
ubuntu 12.10上安装tftpd-hpa 1)安装tftp-hpa,tftpd-hpa sudo apt-get install tftp-hpa tftpd-hpa tftp-hpa是cli ...
- 在排序模型方面,点评搜索也经历了业界比较普遍的迭代过程:从早期的线性模型LR,到引入自动二阶交叉特征的FM和FFM,到非线性树模型GBDT和GBDT+LR,到最近全面迁移至大规模深度学习排序模型。
https://mp.weixin.qq.com/s/wjgoH6-eJQDL1KUQD3aQUQ 大众点评搜索基于知识图谱的深度学习排序实践 原创: 非易 祝升 仲远 美团技术团队 前天
- sql server dba常用概念、操作分析char,varchar,nvarchar,varchar(max)
1.设计表时如何使用char 与 varchar? 请写出你对varchar(max)的理解. 1.设计表时如何使用char 与 varchar? 请写出你对varchar(max)的理解. char ...
- google浏览器mac上跨域问题解决
open -n /Applications/Google\ Chrome.app/ --args --disable-web-security --user-data-dir=/Users/ /Use ...
- hadoop学习---运行第一个hadoop实例
hadoop环境搭建好后,运行第wordcount示例 1.首先启动hadoop:sbin/start-dfs.sh,sbin/start-yarn.sh(必须能够正常运行) 2.进入到hadoo ...
- 使用java进行excel读取和写入
1:添加处理excel的依赖jar包 <!-- 引入poi,解析workbook视图 --> <dependency> <groupId>org.apache.po ...