题意:http://acm.hdu.edu.cn/showproblem.php?pid=1401

给你8*8的棋盘和4个棋子初始位置、最终位置,问你能否在8次操作后达到该状态。

思路:

双向BFS,起点开始正搜4步,终点倒搜4步,map标记。

 #define IOS ios_base::sync_with_stdio(0); cin.tie(0);
#include <cstdio>//sprintf islower isupper
#include <cstdlib>//malloc exit strcat itoa system("cls")
#include <iostream>//pair
#include <fstream>//freopen("C:\\Users\\13606\\Desktop\\Input.txt","r",stdin);
#include <bitset>
//#include <map>
#include<unordered_map>
#include <vector>
#include <stack>
#include <set>
#include <string.h>//strstr substr strcat
#include <string>
#include <time.h>// srand(((unsigned)time(NULL))); Seed n=rand()%10 - 0~9;
#include <cmath>
#include <deque>
#include <queue>//priority_queue<int, vector<int>, greater<int> > q;//less
#include <vector>//emplace_back
//#include <math.h>
#include <cassert>
#include <iomanip>
//#include <windows.h>//reverse(a,a+len);// ~ ! ~ ! floor
#include <algorithm>//sort + unique : sz=unique(b+1,b+n+1)-(b+1);+nth_element(first, nth, last, compare)
using namespace std;//next_permutation(a+1,a+1+n);//prev_permutation
//******************
clock_t __START,__END;
double __TOTALTIME;
void _MS(){__START=clock();}
void _ME(){__END=clock();__TOTALTIME=(double)(__END-__START)/CLOCKS_PER_SEC;cout<<"Time: "<<__TOTALTIME<<" s"<<endl;}
//***********************
#define rint register int
#define fo(a,b,c) for(rint a=b;a<=c;++a)
#define fr(a,b,c) for(rint a=b;a>=c;--a)
#define mem(a,b) memset(a,b,sizeof(a))
#define pr printf
#define sc scanf
#define ls rt<<1
#define rs rt<<1|1
typedef pair<int,int> PII;
typedef vector<int> VI;
typedef unsigned long long ull;
typedef long long ll;
typedef double db;
const double E=2.718281828;
const double PI=acos(-1.0);
const ll INF=(1LL<<);
const int inf=(<<);
const double ESP=1e-;
const int mod=(int)1e9+;
const int N=(int)1e6+; int mp[][];
unordered_map<ull,bool>mark;
struct node
{
ull id;
int step;
};
ull get()
{
ull now=,temp=;
int cnt=-;
for(int i=;i<=;++i)
{
for(int j=;j<=;++j)
{
++cnt;
if(mp[i][j])
now|=temp<<cnt;
}
}
return now;
}
bool ok(int x,int y)
{
return x>=&&x<=&&y>=&&y<=;
}
bool ans;
void bfs(ull start,bool f)
{
queue<node>q;
q.push({start,});
while(!q.empty())
{
node now=q.front();q.pop();
if(!f)
{
if(mark[now.id])continue;
mark[now.id]=;
}
else
{
if(mark[now.id])
{
ans=;
return;
}
}
if(now.step==)continue;
int cnt=-;
for(int i=;i<=;++i)
{
for(int j=;j<=;++j)
{
++cnt;
mp[i][j]=(int)(now.id>>cnt)&;
}
}
for(int i=;i<=;++i)
{
for(int j=;j<=;++j)
{
if(mp[i][j]&&ok(i-,j)&&mp[i-][j]==&&ok(i-,j)&&mp[i-][j]==)
{
mp[i-][j]=,mp[i][j]=;
q.push({get(),now.step+});
mp[i-][j]=,mp[i][j]=;
}
if(mp[i][j]&&ok(i+,j)&&mp[i+][j]==&&ok(i+,j)&&mp[i+][j]==)
{
mp[i+][j]=,mp[i][j]=;
q.push({get(),now.step+});
mp[i+][j]=,mp[i][j]=;
}
if(mp[i][j]&&ok(i,j-)&&mp[i][j-]==&&ok(i,j-)&&mp[i][j-]==)
{
mp[i][j-]=,mp[i][j]=;
q.push({get(),now.step+});
mp[i][j-]=,mp[i][j]=;
}
if(mp[i][j]&&ok(i,j+)&&mp[i][j+]==&&ok(i,j+)&&mp[i][j+]==)
{
mp[i][j+]=,mp[i][j]=;
q.push({get(),now.step+});
mp[i][j+]=,mp[i][j]=;
}
//--------------------------------------------------------------
if(mp[i][j]==&&ok(i-,j)&&mp[i-][j]==)
{
mp[i-][j]=,mp[i][j]=;
q.push({get(),now.step+});
mp[i-][j]=;mp[i][j]=;
}
if(mp[i][j]==&&ok(i+,j)&&mp[i+][j]==)
{
mp[i+][j]=,mp[i][j]=;
q.push({get(),now.step+});
mp[i+][j]=;mp[i][j]=;
}
if(mp[i][j]==&&ok(i,j-)&&mp[i][j-]==)
{
mp[i][j-]=,mp[i][j]=;
q.push({get(),now.step+});
mp[i][j-]=;mp[i][j]=;
}
if(mp[i][j]==&&ok(i,j+)&&mp[i][j+]==)
{
mp[i][j+]=,mp[i][j]=;
q.push({get(),now.step+});
mp[i][j+]=;mp[i][j]=;
}
}
}
}
} int main()
{
int x,y;
while(~sc("%d%d",&x,&y))
{
ans=;
mark.clear();
mem(mp,);
mp[x][y]=;
for(int i=;i<=;++i)
{
sc("%d%d",&x,&y);
mp[x][y]=;
}
bfs(get(),);
mem(mp,);
for(int i=;i<=;++i)
{
sc("%d%d",&x,&y);
mp[x][y]=;
}
bfs(get(),);
if(ans)
pr("YES\n");
else
pr("NO\n");
}
return ;
} /**************************************************************************************/

HDU1401(双向BFS)的更多相关文章

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

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

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

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

  3. POJ 3170 Knights of Ni (暴力,双向BFS)

    题意:一个人要从2先走到4再走到3,计算最少路径. 析:其实这个题很水的,就是要注意,在没有到4之前是不能经过3的,一点要注意.其他的就比较简单了,就是一个双向BFS,先从2搜到4,再从3到搜到4, ...

  4. [转] 搜索之双向BFS

    转自:http://www.cppblog.com/Yuan/archive/2011/02/23/140553.aspx 如果目标也已知的话,用双向BFS能很大程度上提高速度. 单向时,是 b^le ...

  5. 双向BFS

    转自“Yuan” 如果目标也已知的话,用双向BFS能很大提高速度 单向时,是 b^len的扩展. 双向的话,2*b^(len/2)  快了很多,特别是分支因子b较大时 至于实现上,网上有些做法是用两个 ...

  6. HDU 3085 Nightmare Ⅱ (双向BFS)

    Nightmare Ⅱ Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota ...

  7. HDU 3085 Nightmare Ⅱ 双向BFS

    题意:很好理解,然后注意几点,男的可以一秒走三步,也就是三步以内的都可以,鬼可以穿墙,但是人不可以,鬼是一次走两步 分析:我刚开始男女,鬼BFS三遍,然后最后处理答案,严重超时,然后上网看题解,发现是 ...

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

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

  9. Hdu1401-Solitaire(双向bfs)

    Solitaire is a game played on a chessboard 8x8. The rows and columns of the chessboard are numbered ...

随机推荐

  1. while练习

    题目:企业发放的奖金根据利润提成.利润(I)低于或等于10万元时,奖金可提10%:利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%:20万到40万之 ...

  2. 如何更改电脑ip

    首先打开控制面板==>点击网络和internet==>点击网络和共享中心==>点击更改适配器设置==>右键无线连接或宽带连接(视情况而定)==>属性==>双击ipv ...

  3. Spring注解驱动——组件注册系列

    1.@Configuration 从Spring3.0,@Configuration用于定义配置类,可替换xml配置文件,被注解的类内部包含有一个或多个被@Bean注解的方法,这些方法将会被Annot ...

  4. 获取 Django版本号的两种方式

    one k@ubuntu:~$ python Python ( , ::) [GCC ] on linux2 Type "help", "copyright", ...

  5. Liunx之nginx配置

    一.nginx安装 卸载yum安装的ngjnx yum remove nginx -y 编译安装nginx步骤 编译安装nginx的步骤 1.解决软件依赖 yum install gcc patch ...

  6. Codeforces 1276D/1259G Tree Elimination (树形DP)

    题目链接 http://codeforces.com/contest/1276/problem/D 题解 我什么DP都不会做,吃枣药丸-- 设\(f_{u,j}\)表示\(u\)子树内,\(j=0\) ...

  7. League of Leesins

    C - League of Leesins 首先找到每一串数字的头和尾两个数字,这两个数字有一个特点,就是它们在输入数据的时候都只会出现一次.我们在输出的时候用头和尾做第一数都可以. 然后第二个数只会 ...

  8. String 类型的数据强转成int的方法

        有2个方法:1). int i = Integer.parseInt(str); 2). int i = Integer.valueOf(str).intValue();

  9. css定位中的百分比

    ----转载自自己在牛人部落中的相关文章--- 在前端css定位中经常面对的一个问题是,百分比定位究竟是针对于谁定位? 一.margin,padding的百分比 首先从css的设计意图说起,在浏览器默 ...

  10. 查询Oracle正在执行的sql语句及kill被锁的表

    查询Oracle正在执行的sql语句及执行该语句的用户SELECT b.sid oracleID, b.username 登录Oracle用户名, b.serial#, spid 操作系统ID, pa ...