HDU 3567 Eight II BFS预处理
题意:就是八数码问题,给你开始的串和结束的串,问你从开始到结束的最短且最小的变换序列是什么
分析:我们可以预处理打表,这里的这个题可以和HDU1430魔板那个题采取一样的做法
预处理打表,因为八数码问题实际上是每个小块位置的变化,上面的数字只是用来标记位置的,
所以通过映射将初末序列进行置换就好了,然后因为每次的x字符的置换位置不一样
所以需要以123456789这个初始串打9遍表就好了733ms
- #include <iostream>
- #include <cstdio>
- #include <vector>
- #include <cstring>
- #include <algorithm>
- #include <string>
- #include <cmath>
- #include <queue>
- using namespace std;
- const int N=;
- int fac[]= {,,,,,,,,,};
- int aim;
- int cantor(char s[])
- {
- int ans=;
- for(int i=,j=; i<=; ++i,--j)
- {
- int tmp=;
- for(int k=i+; k<=; ++k)
- if(s[i]>s[k])++tmp;
- ans+=(tmp*fac[j]);
- }
- return ans;
- }
- struct Node
- {
- char s[];
- int hs;
- };
- struct asd
- {
- bool vis;
- char c;
- int pre;
- }o[][];
- queue<Node>q;
- void bfs(int pos)
- {
- Node a;
- for(int i=; i<=; ++i)
- a.s[i]=''+i;
- aim=a.hs=cantor(a.s);
- o[pos][a.hs].vis=;
- q.push(a);
- while(!q.empty())
- {
- a=q.front();
- q.pop();
- int now=a.hs;
- int x;
- for(int i=; i<=; ++i)
- if(a.s[i]==''+pos)x=i;
- if(x+<)
- {
- bool flag=;
- swap(a.s[x],a.s[x+]);
- a.hs=cantor(a.s);
- if(o[pos][a.hs].vis)
- flag=;
- if(!flag)
- {
- o[pos][a.hs].vis=;
- o[pos][a.hs].c='d';
- o[pos][a.hs].pre=now;
- q.push(a);
- }
- swap(a.s[x],a.s[x+]);
- }
- if(x%!=)
- {
- bool flag=;
- swap(a.s[x],a.s[x-]);
- a.hs=cantor(a.s);
- if(o[pos][a.hs].vis)
- flag=;
- if(!flag)
- {
- o[pos][a.hs].vis=;
- o[pos][a.hs].c='l';
- o[pos][a.hs].pre=now;
- q.push(a);
- }
- swap(a.s[x],a.s[x-]);
- }
- if(x%)
- {
- bool flag=;
- swap(a.s[x],a.s[x+]);
- a.hs=cantor(a.s);
- if(o[pos][a.hs].vis)
- flag=;
- if(!flag)
- {
- o[pos][a.hs].vis=;
- o[pos][a.hs].c='r';
- o[pos][a.hs].pre=now;
- q.push(a);
- }
- swap(a.s[x],a.s[x+]);
- }
- if(x->)
- {
- bool flag=;
- swap(a.s[x],a.s[x-]);
- a.hs=cantor(a.s);
- if(o[pos][a.hs].vis)
- flag=;
- if(!flag)
- {
- o[pos][a.hs].vis=;
- o[pos][a.hs].c='u';
- o[pos][a.hs].pre=now;
- q.push(a);
- }
- swap(a.s[x],a.s[x-]);
- }
- }
- }
- char s[],t[];
- string res;
- void getres(int u,int pos)
- {
- while(u!=aim)
- {
- res=res+o[pos][u].c;
- u=o[pos][u].pre;
- }
- }
- char mat[];
- int main()
- {
- for(int i=;i<;++i)
- for(int j=;j<=;++j)
- o[j][i].vis=;
- for(int i=;i<=;++i)
- bfs(i);
- int T,cas=;
- scanf("%d",&T);
- while(T--)
- {
- scanf("%s%s",s+,t+);
- int flag;
- for(int i=;i<=;++i)
- {
- if(s[i]=='X')s[i]='',flag=i;
- if(t[i]=='X')t[i]='';
- mat[s[i]-'']=i+'';
- }
- for(int i=;i<=;++i)
- t[i]=mat[t[i]-''];
- int ans=cantor(t);
- res.clear();
- getres(ans,flag);
- printf("Case %d: %d\n",++cas,res.size());
- reverse(res.begin(),res.end());
- cout<<res<<endl;
- }
- return ;
- }
HDU 3567 Eight II BFS预处理的更多相关文章
- HDU - 3567 Eight II (bfs预处理 + 康托) [kuangbin带你飞]专题二
类似HDU1430,不过本题需要枚举X的九个位置,分别保存状态,因为要保证最少步数.要保证字典序最小的话,在扩展节点时,方向顺序为:down, left, right, up. 我用c++提交1500 ...
- HDU 3567 Eight II(八数码 II)
HDU 3567 Eight II(八数码 II) /65536 K (Java/Others) Problem Description - 题目描述 Eight-puzzle, which is ...
- HDU 3533 Escape(BFS+预处理)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3533 题目大意:给你一张n* m的地图,人在起点在(0,0)要到达终点(n,m)有k(k<=10 ...
- HDU - 1430 魔板 (bfs预处理 + 康托)
对于该题可以直接预处理初始状态[0, 1, 2, 3, 4, 5, 6, 7]所有可以到达的状态,保存到达的路径,直接打印答案即可. 关于此处的状态转换:假设有初始状态为2,3,4,5,0,6,7,1 ...
- HDU 3567 Eight II 打表,康托展开,bfs,g++提交可过c++不可过 难度:3
http://acm.hdu.edu.cn/showproblem.php?pid=3567 相比Eight,似乎只是把目标状态由确定的改成不确定的,但是康托展开+曼哈顿为h值的A*和IDA*都不过, ...
- HDU 3567 Eight II
Eight II Time Limit: 2000ms Memory Limit: 65536KB This problem will be judged on HDU. Original ID: 3 ...
- hdu 1430 魔板 (BFS+预处理)
Problem - 1430 跟八数码相似的一题搜索题.做法可以是双向BFS或者预处理从"12345678"开始可以到达的所有状态,然后等价转换过去直接回溯路径即可. 代码如下: ...
- POJ-1077 HDU 1043 HDU 3567 Eight (BFS预处理+康拓展开)
思路: 这三个题是一个比一个令人纠结呀. POJ-1077 爆搜可以过,94ms,注意不能用map就是了. #include<iostream> #include<stack> ...
- HDU 4856 Tunnels(BFS+状压DP)
HDU 4856 Tunnels 题目链接 题意:给定一些管道.然后管道之间走是不用时间的,陆地上有障碍.陆地上走一步花费时间1,求遍历全部管道须要的最短时间.每一个管道仅仅能走一次 思路:先BFS预 ...
随机推荐
- HttpClient抓取网页内容简单介绍
版本HttpClient3.1 1.GET方式 第一步.创建一个客户端,类似于你用浏览器打开一个网页 HttpClient httpClient = new HttpClient(); 第二步.创建一 ...
- Qt智能指针简明说明
下面的智能指针分别对应boost库,Qt库,c++11的智能指针 boost::scoped_ptr QScopedPointer unique_ptr 在其生命期结束后会自动删除它所指的对象(确定 ...
- [转载]iOS本地推送-备用
第一步:创建本地推送// 创建一个本地推送UILocalNotification *notification = [[[UILocalNotification alloc] init] autorel ...
- bnuoj 20838 Item-Based Recommendation (模拟)
http://www.bnuoj.com/bnuoj/problem_show.php?pid=20838 [题意]: 有点长,略. [code]: #include <iostream> ...
- linux usermod修改用户所在组方法
usermod 用户名 -g 组名 -g<群组> 修改用户所属的群组. -G<群组> 修改用户所属的附加群组.
- tomcat 设置默认编码格式
在tomcat目录下 conf文件夹下的server.xml中: <Connector port="80" protocol="HTTP/1.1" ...
- 使用程序获取整型数据和浮点型数据在内存中的表示---gyy整理
使用程序获取整型数据和浮点型数据在内存中的表示. C++中整型(int).短整型(short int).单精度浮点数(float).双精度浮点数(double)在内存中所占字节数不同,因此取值范围也不 ...
- WPF中动态添加xaml资源文件
一.新建一个资源文件,然后设置其Build Actoin(生成操作)为Resource(资源): 二.在App.xaml.cs的StartUp事件或者是你需要的时机代码段写上如下代码: Resourc ...
- Fisher's exact test( 费希尔精确检验)
Fisher's exact test[1][2][3] is a statistical significance test used in the analysis ofcontingency t ...
- 无效的 URI: 未能分析证书颁发机构/主机
出 现该错误的原因是URL中少了一个斜杠,正常的URL是“http:”后边有两个斜杠,而我在修改配置文件中的URL的IP地址部分时,不小心删掉了一个 斜杠,例如:http:/blog.csdn.net ...