hdu 1043 Eight
欸我一直以为双向bfs是搜完一半再搜另一半呢,妹想到是两个一起搜
然后队列里放的结构体里不能直接存答案,所以做一个邻接表一样的东西,直接指向需要的字符即可
记录状态用康托展开来hash
以及居然是多组数据啊?!
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
const int N=500005,has[9]={1,1,2,6,24,120,720,5040,40320},dx[4]={-3,3,-1,1};
int v1[N],v2[N];
char a[30],d1[10]={"udlr"},d2[10]={"durl"};
string b="123456780";
struct qw
{
int a;
char ch;
qw(int A=0,char C=0)
{
a=A,ch=C;
}
}pre[N];
struct qwe
{
int a;
string c;
qwe(int A=0,string C="")
{
a=A,c=C;
}
}e;
void print(int x)
{
if(pre[x].a==-1)
return;
print(pre[x].a);
printf("%c",pre[x].ch);
}
int ha(string e)
{
int s=0,i,j,k;
for(i=0;i<9;i++)
{
k=0;
for(j=0;j<i;j++)
if(e[j]>e[i])
k++;
s+=k*has[i];
}
return s;
}
int main()
{
while(gets(a))
{
int k=0;
e.c="";
for(int i=0,j=0;i<strlen(a);i++)
if(a[i]!=' ')
{
if(a[i]=='x')
e.a=j,e.c+='0';
else
e.c+=a[i];
j++;
}
for(int i=0;i<9;i++)
if(e.c[i]!='0')
for(int j=0;j<i;j++)
if(e.c[j]!='0'&&e.c[j]>e.c[i])
k++;
memset(v2,0,sizeof(v2));
memset(v1,0,sizeof(v1));
if(k&1)
printf("unsolvable\n");
else
{
qwe f,g;
int a=2;
queue<qwe>q1,q2;
v1[ha(e.c)]=1;
pre[1].a=-1,pre[2].a=-1;
f=qwe(8,b);
v2[ha(f.c)]=2;
q1.push(e),q2.push(f);
while(!q1.empty()&&!q2.empty())
{
f=q1.front();
q1.pop();
int p=ha(f.c);
if(v2[p])
{
print(v1[p]);
for(int k=v2[p];pre[k].a!=-1;k=pre[k].a)
printf("%c",pre[k].ch);
printf("\n");
break;
}
for(int i=0;i<4;i++)
if((i!=0||f.a>=3)&&(i!=1||f.a<=5)&&(i!=2||f.a%3!=0)&&(i!=3||f.a%3!=2))
{
int x=f.a+dx[i];
g=f;
swap(g.c[f.a],g.c[x]);
int q=ha(g.c);
if(v1[q])
continue;
v1[q]=++a;
g.a=x;
pre[a]=qw(v1[p],d1[i]);
q1.push(g);
}
f=q2.front();
q2.pop();
p=ha(f.c);
if(v1[p])
{
print(v1[p]);
for(int k=v2[p];pre[k].a!=-1;k=pre[k].a)
printf("%c",pre[k].ch);
printf("\n");
break;
}
for(int i=0;i<4;i++)
if((i!=0||f.a>=3)&&(i!=1||f.a<=5)&&(i!=2||f.a%3!=0)&&(i!=3||f.a%3!=2))
{
int x=f.a+dx[i];
g=f;
swap(g.c[f.a],g.c[x]);
int q=ha(g.c);
if(v2[q])
continue;
v2[q]=++a;
g.a=x;
pre[a]=qw(v2[p],d2[i]);
q2.push(g);
}
}
printf("unsolvable\n");
}
}
return 0;
}
hdu 1043 Eight的更多相关文章
- POJ-1077 HDU 1043 HDU 3567 Eight (BFS预处理+康拓展开)
思路: 这三个题是一个比一个令人纠结呀. POJ-1077 爆搜可以过,94ms,注意不能用map就是了. #include<iostream> #include<stack> ...
- HDU 1043 Eight(八数码)
HDU 1043 Eight(八数码) 00 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Problem Descr ...
- Eight POJ - 1077 HDU - 1043 八数码
Eight POJ - 1077 HDU - 1043 八数码问题.用hash(康托展开)判重 bfs(TLE) #include<cstdio> #include<iostream ...
- HDU - 1043 - Eight / POJ - 1077 - Eight
先上题目: Eight Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tota ...
- HDU 1043 Eight 八数码问题 A*算法(经典问题)
HDU 1043 Eight 八数码问题(经典问题) 题意 经典问题,就不再进行解释了. 这里主要是给你一个状态,然后要你求其到达\(1,2,3,4,5,6,7,8,x\)的转移路径. 解题思路 这里 ...
- POJ 1077 && HDU 1043 Eight A*算法,bfs,康托展开,hash 难度:3
http://poj.org/problem?id=1077 http://acm.hdu.edu.cn/showproblem.php?pid=1043 X=a[n]*(n-1)!+a[n-1]*( ...
- hdu 1043 Eight 经典八数码问题
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1043 The 15-puzzle has been around for over 100 years ...
- hdu 1043 pku poj 1077 Eight (BFS + 康拓展开)
http://acm.hdu.edu.cn/showproblem.php?pid=1043 http://poj.org/problem?id=1077 Eight Time Limit: 1000 ...
- HDU 1043 Eight(双向BFS+康托展开)
http://acm.hdu.edu.cn/showproblem.php?pid=1043 题意:给出一个八数码,求出到达指定状态的路径. 思路:路径寻找问题.在这道题里用到的知识点挺多的.第一次用 ...
- HDU 1043 Eight(反向BFS+打表+康托展开)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1043 题目大意:传统八数码问题 解题思路:就是从“12345678x”这个终点状态开始反向BFS,将各 ...
随机推荐
- nyoj 2 括号配对问题(stack)
括号配对问题 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 现在,有一行括号序列,请你检查这行括号是否配对. 输入 第一行输入一个数N(0& ...
- 编程数学(A-2)-次方
百度百科:次方. 特别是一个数的负次方需要注意.
- 【NOIP2017练习】怎样打好隔膜(贪心,堆,带删除priority_queue)
题意:OI大师抖儿在夺得银牌之后,顺利保送pku.这一天,抖儿问长者:“我的手速虽然已经站在了人类的巅峰,但是打隔膜还是输.我换了很多队友,但是没有用.请问应该怎样打好隔膜?”长者回答:“你啊,Too ...
- bat初学
今天在重置某工具软件试用期时(汗,盗版可耻=_=!,鄙视自己一下),实在懒得每次过了试用期再点开注册表,手工删除了,就想着写个脚本执行一下,这里就想起来了bat文件. 首先介绍一下for循环,从百度知 ...
- Redis2019年3.22
redis缓存技术学习 一. redis基础配置 1. redis简介 1.1 redis 是c语言编写的一个缓存服务器, 是一个内存版本的nosql非关系型数据,大概11w/s访问处理. 数据都在本 ...
- 【转】实现一个自己的promise
转, 原文:http://blog.csdn.net/yibingxiong1/article/details/68075416------------------------------------ ...
- Windows TAKEOWN & ICACLS
TAKEOWN:takeown /f 文件名 获取该文件的所属权takeown /f /r /d n 文件夹 获取整个文件夹及其下面子目录文件的所属权 TAK ...
- [Maid] Write Tasks in Markdown with Maid
Maid enables you to write your tasks in Markdown. Create a maidfile.md or a README.mdthen add Header ...
- Django打造大型企业官网(八)
4.16.侧边栏标题和广告位布局完成 templates/news/index.html <div class="sidebar-wrapper"> <div c ...
- 状压DP问题
状态压缩·一 题目传送:#1044 : 状态压缩·一 AC代码: #include <map> #include <set> #include <list> #in ...