[Swust OJ 1126]--神奇的矩阵(BFS,预处理,打表)
题目链接:http://acm.swust.edu.cn/problem/1126/
上一周里,患有XX症的哈特13成功解决了填数矩阵问题。
不知道他这一周又从哪儿弄来一神奇的矩阵,于是逃课潜心研究了一周,终于发现了其中的奥秘:
该矩阵有2行、4列,即8个小方块,每个小方块上有一个数字,即:
1 2 3 4
5 6 7 8
对于这个神奇的矩阵,有3种变换方式,具体如下:
变换A:上下两行数字互换,如上图可变为:
5 6 7 8
1 2 3 4
变换B:每行同时向右循环移动一格,如上图可变为:
4 1 2 3
8 5 6 7
变换C:中间4个方块顺时针旋转90度,如上图可变为:
1 6 2 4
5 7 3 8
哈特13虽然发现了这些变换规则,但是他并不知道怎么解决如下问题:
现在给出一个初始状态和目标状态,怎么变换才能使得矩阵从初始状态变为目标状态且变换步数最少。如果有多种变换方案,输出变换序号字典序最小的那种方案。
请你帮助他。
多组输入,约1000组,直到文件末尾。
每组数据包括4行,前两行为初始状态,后两行为目标状态。
对于每组输入,输出满足要求的变换方案。
|
1234
5678
5738
1624
|
| CA |
#include<iostream>
#include<cstring>
#include<string>
#include<map>
#include<queue>
using namespace std;
typedef struct{
string path, mpt;
}node;
int vis[];
int cur[] = { , , , , , , , , , };
//依次为1的阶乘,2的阶乘。。。。。8各数在一个数位置确定时剩余 7! 种排列情况,以此类推
string opera[];
/****************************************** 寻找对应状态下对应数字编号!!!!
查找 "当前数" 确定情况下剩下的 "排列"
C(n 1)*(n-i)! 当前数状确定态下的排列种数, 依次递推到最后一位叠加,
每一个状态有且只有一个数对应 *********************************************/
int get_num(string x){
int i, j, a, b, cnt = , book[];
memset(book, , sizeof(book));
for (i = ; i < ; i++){
a = x[i] - '', b = ;
for (j = ; j < a; j++){
if (!book[j])
b++;
}
cnt += b*cur[ - i];
book[a] = ;
}
return cnt + ;
}
void bfs(){
queue<node>Q;
node now, next;
now.mpt = "", now.path = "";
Q.push(now);
vis[get_num(now.mpt)] = ;
while (!Q.empty()){
now = Q.front();
Q.pop();
opera[get_num(now.mpt)] = now.path;
for (int i = ; i < ; i++){
next = now;
if (!i){
next.path += 'A';
swap(next.mpt[], next.mpt[]);
swap(next.mpt[], next.mpt[]);
swap(next.mpt[], next.mpt[]);
swap(next.mpt[], next.mpt[]);
}
else if (i == ){
next.path += 'B';
char s1 = next.mpt[];
for (int j = ; j > ; j--)
next.mpt[j] = next.mpt[j - ];
next.mpt[] = s1;
char s2 = next.mpt[];
for (int j = ; j > ; j--)
next.mpt[j] = next.mpt[j - ];
next.mpt[] = s2;
}
else{
next.path += 'C';
swap(next.mpt[], next.mpt[]);
swap(next.mpt[], next.mpt[]);
swap(next.mpt[], next.mpt[]);
}
if (!vis[get_num(next.mpt)]){
vis[get_num(next.mpt)] = ;
Q.push(next);
}
}
}
}
int main(){
bfs();
string x1, x2, y1, y2;
while (cin >> x1 >> x2 >> y1 >> y2){
x1 += x2, y1 += y2;
pair<char, char>change[];
for (int i = ; i <= ; i++){
change[i].first = x1[i - ];
change[i].second = i + '';
}
for (int i = ; i <= ; i++)
for (int j = ; j <= ; j++){
if (y1[i - ] == change[j].first){
y1[i - ] = change[j].second;
break;
}
}
cout << opera[get_num(y1)] << "\r\n";
//cout << y1;
}
return ;
}
[Swust OJ 1126]--神奇的矩阵(BFS,预处理,打表)的更多相关文章
- [Swust OJ 409]--小鼠迷宫问题(BFS+记忆化搜索)
题目链接:http://acm.swust.edu.cn/problem/409/ Time limit(ms): 1000 Memory limit(kb): 65535 Description ...
- [Swust OJ 715]--字典序问题(组合数预处理/数位dp)
题目链接:http://acm.swust.edu.cn/problem/715/ Time limit(ms): 1000 Memory limit(kb): 65535 在数据加密和数据压缩中 ...
- [Swust OJ 1125]--又见GCD(数论,素数表存贮因子)
题目链接:http://acm.swust.edu.cn/problem/1125/ Time limit(ms): 1000 Memory limit(kb): 65535 Descriptio ...
- BZOJ-1189 紧急疏散evacuate BFS预处理+最大流+二分判定+神建模!!
绝世污题,垃圾题,浪费我一整天青春! 1189: [HNOI2007]紧急疏散evacuate Time Limit: 10 Sec Memory Limit: 162 MB Submit: 1262 ...
- bzoj2396: 神奇的矩阵
与51nod1140一样.不过这题是多组数据的...坑.... #include<cstdio> #include<cstring> #include<cctype> ...
- HDU 3567 Eight II BFS预处理
题意:就是八数码问题,给你开始的串和结束的串,问你从开始到结束的最短且最小的变换序列是什么 分析:我们可以预处理打表,这里的这个题可以和HDU1430魔板那个题采取一样的做法 预处理打表,因为八数码问 ...
- [Swust OJ 404]--最小代价树(动态规划)
题目链接:http://acm.swust.edu.cn/problem/code/745255/ Time limit(ms): 1000 Memory limit(kb): 65535 Des ...
- [Swust OJ 649]--NBA Finals(dp,后台略(hen)坑)
题目链接:http://acm.swust.edu.cn/problem/649/ Time limit(ms): 1000 Memory limit(kb): 65535 Consider two ...
- 神奇的矩阵 NOI模拟题
神奇的矩阵 题目大意 有一个矩阵\(A\),第一行是给出的,接下来第\(x\)行,第\(y\)个元素的值为数字\(A_{x-1,y}\)在\(\{A_{x-1,1},A_{x-1,2},A_{x-1, ...
随机推荐
- BZOJ 1483: [HNOI2009]梦幻布丁( 链表 + 启发式合并 )
把相同颜色的串成一个链表, 然后每次A操作就启发式合并, 然后计算对答案的影响. ----------------------------------------------------------- ...
- 在C语言中基本数据类型所占的字节数
基本数据类型所占的字节数其实跟C语言本身没有太大的关系,它取决于编译器的位数,下面这张表说明了不同编译器下基本数据类型的长度: 32位编译器中各基本类型所占字节数: 注:对于32位的编译器,指针变量的 ...
- PhpStorm 10.0.1安装(win7-64位)
软件下载地址 http://www.xiazaiba.com/html/25261.html#j_down_list 或者:http://pan.baidu.com/s/1brSA9C 密码:tpc7 ...
- CSS3 模拟笑脸
参考 http://www.html5tricks.com/demo/html5-css3-smile-face/index.html 它还做了舌头... 一开始我都是用JS实现的动画 当然了 眼 ...
- BootStrap学习2 typeahead
首先看看这些 http://www.wrapcode.com/bootstrap/typeahead-json-objects/ http://stackoverflow.com/questions/ ...
- 求1+2+...+n
题目:求1+2+…+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字以及条件判断语句(A?B:C). 程序很简单,就看想到想不到了.悲剧,我属于后者... 算 ...
- vs2012-vs2013编译出来的程序不能在xp上运行解决方法
在链接标志中加入参数: /SUBSYSTEM:WINDOWS,"5.01" 在ide环境下: 项目属性-常规-平台工具集-Visual Studio 2013 - Windows ...
- Servlet 基础知识
8.Response 8.1.getOutputStream和getWriter方法分别用于得到输出二进制数据.输出文本数据的ServletOutputStream .Printwriter对象. ...
- 取代奶瓶Minidwep-gtk 破 WPA 全攻略
目录 1. CDlinux 下使用 minidwepgtk 获取握手包并使用自带的字典破解 2. 自带的字典破解不出密码时使用 U 盘外挂字典继续暴力破解密码 3. 将握手包拷贝到 Windows ...
- Intersecting Lines(数学)
Intersecting Lines Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 12844 Accepted: 57 ...