俩月前写的普通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的更多相关文章

  1. UVa 1601 || POJ 3523 The Morning after Halloween (BFS || 双向BFS && 降维 && 状压)

    题意 :w*h(w,h≤16)网格上有n(n≤3)个小写字母(代表鬼).要求把它们分别移动到对应的大写字母里.每步可以有多个鬼同时移动(均为往上下左右4个方向之一移动),但每步结束之后任何两个鬼不能占 ...

  2. POJ1915Knight Moves(单向BFS + 双向BFS)

    题目链接 单向bfs就是水题 #include <iostream> #include <cstring> #include <cstdio> #include & ...

  3. POJ 3126 Prime Path 解题报告(BFS & 双向BFS)

    题目大意:给定一个4位素数,一个目标4位素数.每次变换一位,保证变换后依然是素数,求变换到目标素数的最小步数. 解题报告:直接用最短路. 枚举1000-10000所有素数,如果素数A交换一位可以得到素 ...

  4. UVA - 1601 The Morning after Halloween (BFS/双向BFS/A*)

    题目链接 挺有意思但是代码巨恶心的一道最短路搜索题. 因为图中的结点太多,应当首先考虑把隐式图转化成显式图,即对地图中可以相互连通的点之间连边,建立一个新图(由于每步不需要每个鬼都移动,所以每个点需要 ...

  5. bfs(双向bfs加三维数组)

    http://acm.hdu.edu.cn/showproblem.php?pid=2612 Find a way Time Limit: 3000/1000 MS (Java/Others)     ...

  6. BFS、双向BFS和A*

    BFS.双向BFS和A* Table of Contents 1. BFS 2. 双向BFS 3. A*算法 光说不练是无用的.我们从广为人知的POJ 2243这道题谈起:题目大意:给定一个起点和一个 ...

  7. 洛谷 P1379 八数码难题(map && 双向bfs)

    题目传送门 解题思路: 一道bfs,本题最难的一点就是如何储存已经被访问过的状态,如果直接开一个bool数组,空间肯定会炸,所以我们要用另一个数据结构存,STL大法好,用map来存,直接AC. AC代 ...

  8. 双向BFS和启发式搜索的应用

    题目链接 P5507 机关 题意简述   有12个旋钮,每个旋钮开始时处于状态 \(1\) ~ \(4\) ,每次操作可以往规定方向转动一个旋钮 (\(1\Rightarrow2\Rightarrow ...

  9. HDU 3085 Nightmare II 双向bfs 难度:2

    http://acm.hdu.edu.cn/showproblem.php?pid=3085 出的很好的双向bfs,卡时间,普通的bfs会超时 题意方面: 1. 可停留 2. ghost无视墙壁 3. ...

随机推荐

  1. kswapd和pdflush

    首 先,它们存在的目的不同,kswap的作用是管理内存,pdflush的作用是同步内存和磁盘,当然因为数据写入磁盘前可能会换存在内存,这些缓存真正写 入磁盘由三个原因趋势:1.用户要求缓存马上写入磁盘 ...

  2. [工具]ps

    ps 如果想看一个进程的启动时间,可以用lstart来看 [root@jiangyi02.sqa.zmf /home/ahao.mah] #ps -eo pid,lstart,etime,cmd |g ...

  3. Unittest加载执行用例的方法总结

    前言 说到测试框架,unittest是我最先接触的自动化测试框架之一了, 而且也是用的时间最长的, unittest框架有很多方法加载用例,让我们针对不同的项目,不同项目的大小及用例的多少自己选择加载 ...

  4. enote笔记语言(3)

    what&why(why not)&how&when&where&which:紫色,象征着神秘而又潜蕴着强大的力量,故取紫色. key&key-memo ...

  5. 猜数字游戏的提示(Master-Mind Hints, UVa 340)

    实现一个经典"猜数字"游戏. 给定答案序列和用户猜的序列,统计有多少数字位置正确 (A),有多少数字在两个序列都出现过但位置不对(B). 输入包含多组数据.每组输入第一行为序列长度 ...

  6. -------------Django-----URLS路由

    一.相约Django. 1.Django的特点:Django定义了服务分布.路由映射.模板编程.数据处理的一套完整的功能. (1)集成数据访问组件:Django的model层自带数据库ORM组件. ( ...

  7. 小白神器 - 一篇博客学会HTML

    小白神器 - 一篇博客学会HTML 一. 简介 1. HTML 定义 htyper text markup language  即超文本标记语言. 超文本: 就是指页面内可以包含图片.链接,甚至音乐. ...

  8. PAT 1103 Integer Factorization

    The K-P factorization of a positive integer N is to write N as the sum of the P-th power of K positi ...

  9. elasticsearch match和match_phrase匹配原则(十)

    分词测试 分词后倒排索引结果:可以通过http://127.0.0.1:9200/_analyze 测试 { "analyzer":"ik_max_word", ...

  10. [TyvjP1515] 子串统计 [luoguP2408] 不同子串个数(后缀数组)

    Tyvj传送门 luogu传送门 经典题 统计一个字符串中不同子串的个数 一个字符串中的所有子串就是所有后缀的前缀 先求出后缀数组,求出后缀数组中相邻两后缀的 lcp 那么按照后缀数组中的顺序遍历求解 ...