对于该题可以直接预处理初始状态[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预处理 + 康托)的更多相关文章

  1. hdu 1430 魔板 (BFS+预处理)

    Problem - 1430 跟八数码相似的一题搜索题.做法可以是双向BFS或者预处理从"12345678"开始可以到达的所有状态,然后等价转换过去直接回溯路径即可. 代码如下: ...

  2. hdu.1430.魔板(bfs + 康托展开)

    魔板 Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submis ...

  3. HDU 1430 魔板(康托展开+BFS+预处理)

    魔板 Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submis ...

  4. [HDU 1430] 魔板

    魔板 Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...

  5. HDU - 1430 魔板 【BFS + 康托展开 + 哈希】

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1430 思路 我刚开始 想到的 就是 康托展开 但是这个题目是 多组输入 即使用 康托展开 也是会T的 ...

  6. hdu 1430 魔板 康托展开 + 很好的映射

    http://acm.hdu.edu.cn/showproblem.php?pid=1430 如果从start ---> end,每一次都bfs进行,那么就肯定会超时. 考虑到先把start映射 ...

  7. HDU - 3567 Eight II (bfs预处理 + 康托) [kuangbin带你飞]专题二

    类似HDU1430,不过本题需要枚举X的九个位置,分别保存状态,因为要保证最少步数.要保证字典序最小的话,在扩展节点时,方向顺序为:down, left, right, up. 我用c++提交1500 ...

  8. hdu1430魔板(BFS+康托展开)

    做这题先看:http://blog.csdn.net/u010372095/article/details/9904497 Problem Description 在魔方风靡全球之后不久,Rubik先 ...

  9. HDU 3567 Eight II BFS预处理

    题意:就是八数码问题,给你开始的串和结束的串,问你从开始到结束的最短且最小的变换序列是什么 分析:我们可以预处理打表,这里的这个题可以和HDU1430魔板那个题采取一样的做法 预处理打表,因为八数码问 ...

随机推荐

  1. 转-HTTP POST GET SOAP本质区别详解

    原文链接:HTTP POST GET SOAP本质区别详解 一 原理区别 一般在浏览器中输入网址访问资源都是通过GET方式:在FORM提交中,可以通过Method指定提交方式为GET或者POST,默认 ...

  2. C语言学习之递归

    学习C语言到递归时,还记得那个用来抛砖引玉的例子: "从前呀,有座山,山里有个老和尚给一个小和尚讲故事,讲的什么故事呢?从前呀,有座山,山里有个老和尚给一个小和尚讲故事,讲的什么故事呢?从前 ...

  3. Asp.net core 2.0.1 Razor 的使用学习笔记(三)

    ASP.net core 2.0.0 中 asp.net identity 2.0.0 的基本使用(二)—用户账户及cookie配置 修改用户账户及cookie配置 一.修改密码强度和用户邮箱验证规则 ...

  4. PHP与XML

    代码: <?php $dom= new DomDocument('1.0'); $books=$dom->appendChild($dom->createElement_x_x('b ...

  5. Not Found The requested URL / was not found on this server.

    http://www.wanysys.cc/coding/php/800.html 今天在做本地PHP项目的时候,想把之前wampserver的本地虚拟服务器环境访问方式改为本地localhost访问 ...

  6. nodejs爬虫笔记(二)---代理设置

    node爬虫代理设置 最近想爬取YouTube上面的视频信息,利用nodejs爬虫笔记(一)的方法,代码和错误如下 var request = require('request'); var chee ...

  7. vue调试神器vue-devtools安装

    vue-devtools安装 vue-devtools是一款用来调试Vue应用的Chrome插件,可极大提高开发者调试项目效率,接着我们说一下如何下载安装这个插件; 一. 从chrome商店直接下载安 ...

  8. 小白入门Docker基础篇

    docker是什么 百科上的解释是这样的: Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化 ...

  9. node-glob的*匹配

    目录结构 src/js/libs/app.js src/js/index.js 测试脚本 var glob = require('glob') glob('', {}, function (err, ...

  10. XML实体解析器的作用

    XML实体解析器的作用 什么是实体解析器 如果一个sax解析器需要实现对外部实体的自定义处理,那么必须实现一个EntityResolver接口并且注册到SAX驱动上. 从这段文字可以看出来,实体解析器 ...