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,将各 ...
随机推荐
- POJ-1679 The Unique MST,次小生成树模板题
The Unique MST Time Limit: 1000MS Memory Limit: 10000K Description Given a connected undirec ...
- [Oracle, MySQL] Oracle通过dblink连接MySQL
http://blog.csdn.net/dbanote/article/details/10488581 版权声明:本文为博主原创文章,未经博主允许不得转载. 业务上有这么一个需求,需要把Oracl ...
- MySQL-Transfer2.2发布
http://dinglin.iteye.com/blog/1888640 Transfer 2.2发布.下载地址 版本说明 1. 基于版本 Percona-5.5.31 ,简单用法是先安装好官方或 ...
- 【转】Java中的IO操作
在使用io操作之前,先看一下java中的文件类File如何使用.File包括文件和目录,对文件和目录的操作是新建目录mkdir,新建文件createNewFile,删除文件和目录delete,以及其他 ...
- vue2.0一个书城实例
gitHub克隆地址 git clone https://github.com/Webxiaoyaun/vue-book.git 点击去Github下载 ## 一个书城 ## 有增加,修改,缓存,懒加 ...
- codeforces Gym 100735 D、E、G、H、I
http://codeforces.com/gym/100735 D题 直接暴力枚举 感觉这道题数据有点问题 为什么要先排下序才能过?不懂.. #include <stdio.h> #in ...
- kkpager的改进,Ajax数据变化但是页码不变的问题
原文:http://blog.csdn.net/xiaojian1018/article/details/45564051 kkpager 是一个简单分页展示插件,需要依赖jquery.下载地址:ht ...
- 【结果发布】第六届SeedCoder编程大赛初赛结果发布
微软俱乐部科技文化月seedcoder2014编程大赛已经初审完成. 评审小组选出最棒的作品进入决赛(现场答辩+陈述环节,由评委现场打分).终于排名由"初赛分数+现场答辩分"决定. ...
- C++之桟的应用---括号匹配
刚開始学习数据结构.用桟写了一个经典的应用,括号匹配. 算法思路: 输入字符串时.将 '(' , '[' 压入桟.遇到 ')' ']' 时,再栈顶出桟.进行括号匹配.假设成功匹配.则继续进行.否 ...
- 比真机还快的Android模拟器——Genymotion
比真机还快的Android模拟器--Genymotion ----转载请注明出处:coder-p ...