HDU - 1430 魔板 (bfs预处理 + 康托)
对于该题可以直接预处理初始状态[0, 1, 2, 3, 4, 5, 6, 7]所有可以到达的状态,保存到达的路径,直接打印答案即可。
关于此处的状态转换:假设有初始状态为2,3,4,5,0,6,7,1,目标状态为7,1,4,5,2,3,0,6,首先把初态看做0,1,2,3,4,5,6,7,那么目标状态应该看做6,7,2,3,0,1,4,5直接查询到达状态6,7,2,3,0,1,4,5的路径即可。
PS:hdu3567与这题类似。
AC代码:93ms
#include<cstdio>
#include<cstring>
#include<queue>
#include<string>
#include<iostream>
#include<algorithm>
using namespace std;
typedef int state[8];
const int maxn = 45000;
int vis[maxn];
string path[maxn];
int op[][8] = {
4, 5, 6, 7, 0, 1, 2, 3,
3, 0, 1, 2, 7, 4, 5, 6,
0, 5, 1, 3, 4, 6, 2, 7
};
char dir[] = {'A', 'B', 'C'};
int st[] = {0, 1, 2, 3, 4, 5, 6, 7};
int fact[8];
void deal() { //1~8阶乘打表,方便编码
fact[0] = 1;
for(int i = 1; i < 8; ++i) fact[i] = fact[i - 1] * i;
}
int KT(int *a) { //康托
int code = 0;
for(int i = 0; i < 8; ++i) {
int cnt = 0;
for(int j = i + 1; j < 8; ++j) if(a[j] < a[i]) cnt++;
code += fact[7 - i] * cnt;
}
return code;
}
struct node{
int a[8];
int code;
node(){
}
node(int *b, int code):code(code) {
memcpy(a, b, sizeof(a));
}
};
void walk(int c, int *a) { //对数组进行第c种操作
int b[8];
memcpy(b, a, sizeof(b));
for(int i = 0; i < 8; ++i) {
a[i] = b[op[c][i]];
}
}
void bfs() { //预处理所有可以到达的状态
memset(vis, 0, sizeof(vis));
int code = KT(st);
vis[code] = 1;
path[code] = "";
queue<node>q;
q.push(node(st, code));
while(!q.empty()){
node p = q.front();
q.pop();
int a[8];
for(int i = 0; i < 3; ++i) { //三种操作
memcpy(a, p.a, sizeof(a));
walk(i, a);
code = KT(a);
if(!vis[code]) {
vis[code] = 1;
path[code] = path[p.code] + dir[i];
q.push(node(a, code));
}
}
}
}
void deal(int *a) {
swap(a[4], a[7]);
swap(a[5], a[6]);
}
int main() {
deal();
bfs();
int a[8], b[8], ha[8];
char s[20];
while(scanf("%s", s) == 1) {
for(int i = 0; i < 8; ++i) {
a[i] = s[i] - '0' - 1;
}
deal(a);
for(int i = 0; i < 8; ++i) {
ha[a[i]] = i;
}
scanf("%s", s);
for(int i = 0; i < 8; ++i) {
b[i] = s[i] - '0' - 1;
}
deal(b);
for(int i = 0; i < 8; ++i) a[i] = ha[b[i]];
int code = KT(a);
cout << path[code] << endl;
//cout << "HELLO" <<endl;
}
return 0;
}
如有不当之处欢迎指出!
HDU - 1430 魔板 (bfs预处理 + 康托)的更多相关文章
- hdu 1430 魔板 (BFS+预处理)
Problem - 1430 跟八数码相似的一题搜索题.做法可以是双向BFS或者预处理从"12345678"开始可以到达的所有状态,然后等价转换过去直接回溯路径即可. 代码如下: ...
- hdu.1430.魔板(bfs + 康托展开)
魔板 Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...
- HDU 1430 魔板(康托展开+BFS+预处理)
魔板 Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...
- [HDU 1430] 魔板
魔板 Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...
- HDU - 1430 魔板 【BFS + 康托展开 + 哈希】
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1430 思路 我刚开始 想到的 就是 康托展开 但是这个题目是 多组输入 即使用 康托展开 也是会T的 ...
- hdu 1430 魔板 康托展开 + 很好的映射
http://acm.hdu.edu.cn/showproblem.php?pid=1430 如果从start ---> end,每一次都bfs进行,那么就肯定会超时. 考虑到先把start映射 ...
- HDU - 3567 Eight II (bfs预处理 + 康托) [kuangbin带你飞]专题二
类似HDU1430,不过本题需要枚举X的九个位置,分别保存状态,因为要保证最少步数.要保证字典序最小的话,在扩展节点时,方向顺序为:down, left, right, up. 我用c++提交1500 ...
- hdu1430魔板(BFS+康托展开)
做这题先看:http://blog.csdn.net/u010372095/article/details/9904497 Problem Description 在魔方风靡全球之后不久,Rubik先 ...
- HDU 3567 Eight II BFS预处理
题意:就是八数码问题,给你开始的串和结束的串,问你从开始到结束的最短且最小的变换序列是什么 分析:我们可以预处理打表,这里的这个题可以和HDU1430魔板那个题采取一样的做法 预处理打表,因为八数码问 ...
随机推荐
- Linux指令--文件和目录属性
对于每一个Linux学习者来说,了解Linux文件系统的目录结构,是学好Linux的至关重要的一步.,深入了解linux文件目录结构的标准和每个目录的详细功能,对于我们用好linux系统只管重要,下面 ...
- PHP实现QQ登录的开发教程
第三方登录,就是使用大家比较熟悉的比如QQ.微信.微博等第三方软件登录自己的网站,这可以免去注册账号.快速留住用户的目的,免去了相对复杂的注册流程.下边就给大家讲一下怎么使用PHP开发QQ登录的功能. ...
- 【Python3之迭代器,生成器】
一.可迭代对象和迭代器 1.迭代的概念 上一次输出的结果为下一次输入的初始值,重复的过程称为迭代,每次重复即一次迭代,并且每次迭代的结果是下一次迭代的初始值 注:循环不是迭代 while True: ...
- python 爬虫入门----案例爬取上海租房图片
前言 对于一个net开发这爬虫真真的以前没有写过.这段时间学习python爬虫,今天周末无聊写了一段代码爬取上海租房图片,其实很简短就是利用爬虫的第三方库Requests与BeautifulSoup. ...
- 小z的袜子
传送门 题目描述 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命-- 具体来说,小Z把这N只袜子从 ...
- 强大的API测试工具Hitchhiker v0.9 基于UI的断言测试,回顾2017
v0.9是Hitchhiker在2017农历年的最后一个版本,而起点正是刚过完2016农历年,农历2018即将到来,一年轮回,今天写点东西稍微回顾下hitchhiker的2017. 先还是说v0.9, ...
- 【原创】Struts2.5.12版本中使用通配符*
ι 版权声明:本文为博主原创文章,未经博主允许不得转载. <package name="hellodemo" extends="struts-default&quo ...
- gulp最简示例
全局安装 $ npm gulp -g 作为项目的开发依赖安装 $ npm gulp --save-dev 脚本文件 在根目录创建gulpfile.js文件 const gulp = require(' ...
- jsp中实现点击文件名称完成下载
1.文件名称添加点击事件 <a href="javascript:void(0);" id="wjm" onclick="wjxz();&quo ...
- C# Ioc ASP.NET MVC Dependency Injection
ASP.NET MVC Dependency Injection 同志们,非常快速的Ioc注册接口和注入Mvc Controller,步骤如下: 安装Unity.Mvc NuGet Package 在 ...