POJ1915 BFS&双向BFS
俩月前写的普通BFS
#include <cstdio>
#include <iostream>
#include <cstring>
#include <queue>
using namespace std;
int CAS,sx,sy,k,ex,ey,vis[305][305],xx[]={1,-1,2,-2,1,-1,2,-2},yy[]={2,-2,1,-1,-2,2,-1,1};
bool check(int x,int y)
{
return x>=0&&x<k&&y>=0&&y<k;
}
int bfs()
{
queue <int> p,q;
p.push(sx),q.push(sy);
while(!p.empty())
{
int tempx=p.front(),tempy=q.front();
p.pop();q.pop();
if(tempx==ex&&tempy==ey) return vis[ex][ey];
for(int i=0;i<=7;i++)
{
if(!vis[tempx+xx[i]][tempy+yy[i]]&&check(tempx+xx[i],tempy+yy[i]))
{
vis[tempx+xx[i]][tempy+yy[i]]=vis[tempx][tempy]+1;
p.push(tempx+xx[i]),q.push(tempy+yy[i]);
}
}
}
}
int main()
{
scanf("%d",&CAS);
for(int ii=1;ii<=CAS;ii++)
{
memset(vis,0,sizeof(vis));
scanf("%d%d%d%d%d",&k,&sx,&sy,&ex,&ey);
cout<<bfs()<<endl;
}
}
双向搜索(自己yy的。。。随便搞一搞就AC了 我也不知道为什么。。):
#include <queue>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int cases,dx,dy,k,sx,sy,ex,ey,xx[]={2,2,-2,-2,1,1,-1,-1},yy[]={1,-1,1,-1,2,-2,2,-2},vis[305][305],v[305][305];
queue<pair<int,int> >q;
pair<int,int>p;
int bfs(){
while(!q.empty()){
p=q.front();q.pop();
if(vis[p.first][p.second]==1)
for(int i=0;i<=7;i++){
dx=p.first+xx[i],dy=p.second+yy[i];
if(!vis[dx][dy]&&dx>=0&&dx<k&&dy>=0&&dy<k)v[dx][dy]=v[p.first][p.second]+1,vis[dx][dy]=1,q.push(make_pair(dx,dy));
else if(vis[dx][dy]==2)return v[dx][dy]+v[p.first][p.second];
}
else if(vis[p.first][p.second]==2)
for(int i=0;i<=7;i++){
dx=p.first+xx[i],dy=p.second+yy[i];
if(!vis[dx][dy]&&dx>=0&&dx<k&&dy>=0&&dy<k)v[dx][dy]=v[p.first][p.second]+1,vis[dx][dy]=2,q.push(make_pair(dx,dy));
else if(vis[dx][dy]==1)return v[dx][dy]+v[p.first][p.second];
}
}
}
int main()
{
scanf("%d",&cases);
for(int ii=1;ii<=cases;ii++){
memset(vis,0,sizeof(vis));
memset(v,0,sizeof(v));
scanf("%d%d%d%d%d",&k,&sx,&sy,&ex,&ey);
q.push(make_pair(sx,sy)),q.push(make_pair(ex,ey));
vis[sx][sy]=v[sx][sy]=1;vis[ex][ey]=2;
if(sx==ex&&sy==ey){printf("0\n");continue;}
printf("%d\n",bfs());
while(!q.empty())q.pop();
}
}
POJ1915 BFS&双向BFS的更多相关文章
- UVa 1601 || POJ 3523 The Morning after Halloween (BFS || 双向BFS && 降维 && 状压)
题意 :w*h(w,h≤16)网格上有n(n≤3)个小写字母(代表鬼).要求把它们分别移动到对应的大写字母里.每步可以有多个鬼同时移动(均为往上下左右4个方向之一移动),但每步结束之后任何两个鬼不能占 ...
- POJ1915Knight Moves(单向BFS + 双向BFS)
题目链接 单向bfs就是水题 #include <iostream> #include <cstring> #include <cstdio> #include & ...
- POJ 3126 Prime Path 解题报告(BFS & 双向BFS)
题目大意:给定一个4位素数,一个目标4位素数.每次变换一位,保证变换后依然是素数,求变换到目标素数的最小步数. 解题报告:直接用最短路. 枚举1000-10000所有素数,如果素数A交换一位可以得到素 ...
- UVA - 1601 The Morning after Halloween (BFS/双向BFS/A*)
题目链接 挺有意思但是代码巨恶心的一道最短路搜索题. 因为图中的结点太多,应当首先考虑把隐式图转化成显式图,即对地图中可以相互连通的点之间连边,建立一个新图(由于每步不需要每个鬼都移动,所以每个点需要 ...
- bfs(双向bfs加三维数组)
http://acm.hdu.edu.cn/showproblem.php?pid=2612 Find a way Time Limit: 3000/1000 MS (Java/Others) ...
- BFS、双向BFS和A*
BFS.双向BFS和A* Table of Contents 1. BFS 2. 双向BFS 3. A*算法 光说不练是无用的.我们从广为人知的POJ 2243这道题谈起:题目大意:给定一个起点和一个 ...
- 洛谷 P1379 八数码难题(map && 双向bfs)
题目传送门 解题思路: 一道bfs,本题最难的一点就是如何储存已经被访问过的状态,如果直接开一个bool数组,空间肯定会炸,所以我们要用另一个数据结构存,STL大法好,用map来存,直接AC. AC代 ...
- 双向BFS和启发式搜索的应用
题目链接 P5507 机关 题意简述 有12个旋钮,每个旋钮开始时处于状态 \(1\) ~ \(4\) ,每次操作可以往规定方向转动一个旋钮 (\(1\Rightarrow2\Rightarrow ...
- HDU 3085 Nightmare II 双向bfs 难度:2
http://acm.hdu.edu.cn/showproblem.php?pid=3085 出的很好的双向bfs,卡时间,普通的bfs会超时 题意方面: 1. 可停留 2. ghost无视墙壁 3. ...
随机推荐
- CAD调用导角命令,并返回导角的圆弧对象
主要用到函数说明: _DMxDrawX::SendStringToExecuteFun 把命令当着函数执行,可以传参数,详细说明如下: 参数 说明 IDispatch* pParam 命令参数,IMx ...
- join 和 left join 和 right join的区别?
join等价于 inner join 是内连接 ,返回两个表都有的符合条件的行. left join 是左连接,返回坐表中所有的行以及右表中符合条件的行. right join右连接,是返回右表中所有 ...
- How To: set udev rule for setting the disk permission on ASM disks when using multipath on Linux 6.x
在RHEL6.4上安装11gR2的RAC时,使用了MULTIPATH来聚合绑定多路径的磁盘,并且修改磁盘的权限,赋予grid:asmadmin用户和组. 此时,在安装时可以发现磁盘,日志如下 INFO ...
- 49.ardinality算法之优化内存开销以及HLL算法
主要知识点 precision_threshold参数的理解 HLL算法优化(hash) cardinality,count(distinct),5%的错误率,性能在100ms左右 ...
- 实验十二 团队作业8:软件测试与Alpha冲刺 第五天
项目 内容 这个作业属于哪个课程 老师链接 这个作业的要求在哪里 实验十二 团队作业8:软件测试与Alpha冲刺 团队名称 Always Run! 作业学习目标 (1)掌握软件测试基础技术 (2)学习 ...
- LSB、MSB是什么单位
最低有效位 (LSB: Least Significant Bit) 最低有效位(LSB)是给这些单元值的一个二进制整数位位置,就是,决定是否这个数字是偶数或奇数.LSB有时候是指最右边的位,因为 ...
- [poj3735] Training little cats_矩乘快速幂
Training little cats poj-3735 题目大意:给你n个数,k个操作,将所有操作重复m次. 注释:三种操作,将第i个盒子+1,交换两个盒子中的个数,将一个盒子清空.$1\le m ...
- window7 查找与杀掉占用端口的进程
1.netstat -ano | findstr 3000 2.tasklist | findstr pid 3. taskkill -f -t -im 进程名
- MyBatis 3模糊查询(like)写法(转)
说明:以下写法可以同时支持XML和注解的形式. 1.SQL中字符串拼接 SELECT * FROM tableName WHERE name LIKE CONCAT(CONCAT('%', #{tex ...
- PDF在线预览-pdfjs使用
请参考我的开源: https://github.com/wuyechun2018/itools/blob/master/src/main/webapp/WEB-INF/views/pdf/index. ...