小蟹是一名魔法少女,能熟练的施放很多魔法。

有一天魔法学院上课的时候出现了这样一道题,给一个6位数,让大家用自己的魔法,把这个6位数变成另一个给定的6位数。

小蟹翻了下魔法书,发现她有以下6种魔法:

  1. 将当前魔杖指向的数字与最左端的一个数字调换位置。

  2. 将当前魔杖指向的数字与最右端的一个数字调换位置。

  3. 将当前魔杖指向的数字+1。(若当前魔杖指向的数字为9则无效)

  4. 将当前魔杖指向的数字−1。(若当前魔杖指向的数字为0则无效)

  5. 将当前魔杖向右移动一位。

  6. 将当前魔杖向左移动一位。

最开始,她的魔杖指向的是最左边的数字。

于是小蟹很好奇,以她的能力,施展几次魔法能完成老师的这道题呢?

Input

多组数据,请处理至文件结束(EOF)

对于每组数据,包含两个6位数,a,b。

Output

对于每组数据,输出一个数,代表最少施展魔法的次数。

Sample input and output

Sample Input Sample Output
123456 654321
11

解题报告

不好想。。肯定不能处理操作3和操作4,那样bfs直接爆炸。。。本题连A*也不行。。因为状态数实在太多,又是多Case。。

难保不TLE,因此我们预处理出魔杖能到达地方的状态,之后扫一遍所有状态,加上差值就完辣

 #include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
using namespace std; const int MaxHashSize = ;
const int MaxStatusSize = ;
typedef struct status
{
int step,value;
bool arrive[];
}; int Head[MaxHashSize];
int Next[MaxStatusSize];
status st[MaxStatusSize];
int caculate[] = {,,,,,,};
int tar_num[]; void Hash_init()
{
memset(Head,-,sizeof(Head));
} int GetHashNum(int& x)
{
return x % MaxHashSize;
} bool insert_Hash(int id)
{
int h = GetHashNum(st[id].value);
int t = Head[h];
while(t != -)
{
if(st[id].value == st[t].value)
return false;
t = Next[t];
}
Next[id] = Head[h];
Head[h] = id;
return true;
} int bfs()
{
int front = ,rear = ;
insert_Hash();
while(front < rear)
{
status ss = st[front++];
int num[];
int ori = ss.value;
for(int i = ; i >= ; --i)
{
num[i] = ss.value % ;
ss.value /= ;
}
int pos = num[];
bool flag = true;
if (num[pos] == || pos == ) flag = false;
if (flag)
{
st[rear] = ss;
int temp = num[];
num[] = num[pos];
num[pos] = temp;
int value = ;
for(int i = ; i < ; ++ i)
value += (num[i]*caculate[i]);
st[rear].value = value;
if (insert_Hash(rear))
{
st[rear].step = ss.step + ;
st[rear++].arrive[] = true;
}
num[pos] = num[];
num[] = temp;
}
flag = true;
if (num[] == && pos == ) flag = false;
if (pos == ) flag = false;
if (flag)
{
st[rear] = ss;
int temp = num[];
num[] = num[pos];
num[pos] = temp;
int value = ;
for(int i = ; i < ; ++ i)
value += (num[i]*caculate[i]);
st[rear].value = value;
if (insert_Hash(rear))
{
st[rear].step = ss.step + ;
st[rear++].arrive[] = true;
}
num[pos] = num[];
num[] = temp;
}
if (pos < )
{
st[rear] = ss;
int value = ori + ;
st[rear].value = value;
if (insert_Hash(rear))
{
st[rear].step = ss.step + ;
st[rear++].arrive[pos+] = true;
}
}
if (pos > )
{
st[rear] = ss;
int value = ori - ;
st[rear].value = value;
if (insert_Hash(rear))
{
st[rear].step = ss.step + ;
st[rear++].arrive[pos-] = true;
}
}
}
return rear;
} int slove(int x)
{
int Mo = ;
for(int i = ; i < x; ++ i)
{
//cout << "i is " << i << endl;
int num[];
st[i].value /= ;
int ori = st[i].value;
for(int j = ;j >= ;--j)
{
num[j] = st[i].value % ;
st[i].value /= ;
}
int res = st[i].step;
for(int k = ; k < ;++k)
if (tar_num[k] != num[k] && !st[i].arrive[k])
{
res = ;
break;
}
else
res += (abs(tar_num[k]-num[k]));
//cout << "Res is " << res << endl;
Mo = min(Mo,res);
}
return Mo;
} int main(int argc, char * argv[])
{
int s1,s2;
while(scanf("%d%d",&s1,&s2) == )
{
Hash_init();
st[].value = s1*;
st[].step = ;
memset(st[].arrive,false,sizeof(st[].arrive));
st[].arrive[] = true;
for(int i = ;i>=;--i)
{
tar_num[i] = s2 % ;
s2 /= ;
}
cout << slove(bfs()) << endl;
}
return ;
}

UESTC_魔法少女小蟹 CDOJ 710的更多相关文章

  1. UESTC_树上战争 CDOJ 32

    给一棵树,如果树上的某个节点被某个人占据,则它的所有儿子都被占据,lxh和pfz初始时分别站在两个节点上,谁当前所在的点被另一个人占据,他就输了比赛,问谁能获胜. Input 输入包含多组数据 每组第 ...

  2. UESTC_温泉旅店 CDOJ 878

    天空飘下一朵一朵的雪花,这是一片纯白的世界. 在天空之下的温泉旅店里,雪菜已醉倒在一旁,冬马与春希看了看说着梦话的雪菜,决定找一点玩的来度过这愉快的晚上. 这家旅店提供一种特色游戏,游戏有n张牌,各写 ...

  3. UESTC_贪吃蛇 CDOJ 709

    相信大家都玩过贪吃蛇游戏吧. 在n×m的迷宫中,有着一条长度不超过9的贪吃蛇,它已经将所有的食物吃光了,现在的目标是移动到出口. 它走的时候不能碰到自己的身体,也不能碰到墙壁.(如果贪吃蛇的长度> ...

  4. 2014 UESTC暑前集训搜索专题解题报告

    A.解救小Q BFS.每次到达一个状态时看是否是在传送阵的一点上,是则传送到另一点即可. 代码: #include <iostream> #include <cstdio> # ...

  5. UESTC_敢说就敢做 CDOJ 631

    敢说就敢做 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Sta ...

  6. UESTC_方老师的分身 II CDOJ 915

    方老师的分身 II Time Limit: 10000/5000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submi ...

  7. UESTC_方老师分身 I CDOJ 914

    方老师分身 I Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit S ...

  8. UESTC_握手 CDOJ 913

    握手 Time Limit: 2000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status ...

  9. UESTC_神秘绑架案 CDOJ 881

    神秘绑架案 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Sta ...

随机推荐

  1. Array vs Linked List

    Access: Random / Sequential 1. Array element can be randomly accessed using index 2. Random access f ...

  2. Kafka的Producer以及Consumer远程调用问题

    公司需要分布式的JMS,所以研究了Kafka,之前在本地都没有出现问题,但是在服务器上布Kafka的时候发现了消费者无法消费的问题. kafka布到一台服务器上面,由于业务原因,producer和ka ...

  3. bash的元字符(下)

    ` "Esc"键正下方键,替换命令 PS1=`command` {} 在当前shell中运行命令 {command1;command2} | 创建命令间的管道 command1 | ...

  4. 机房收费系统合作版(三)——UI思索

    案件追踪系统1.0暂告一段落.验收过程中.MR MI针对UI界面提出了很多自己的想法. 针对TGB项目的UI设计我也有我的感受: 1.不论大小项目.仅仅要一看界面准有70%到80%熟悉度. 2.一看这 ...

  5. 一、cocos2dx概念简介

    cocos2dx概念介绍 1)scene,继承自CCScene 场景,一个游戏运行期间的显示界面,一个应用里面可以有多个场景,但是每次只能有一个是激活状态,也可以理解为一次只能显示一个界面. 例如,你 ...

  6. java中的二进制

    (1)按位与运算 & 1 & 1 = 1, 0 & 1 = 0 51 & 5  即 0011  0011 & 0000  0101 =0000 0001 = 1 ...

  7. 解决ActiveX Control异常:"没有注册类(异常来自 HRESULT:0x80040154(REGDB_E_CLASSNOTREG))"

    问题背景: 1.我们的程序是用winform调用unity web player 插件来作为播放器在客户端播放动画文件的. 2.播放器是由我们的客户端程序调用的 3.客户端程序默认是以管理员身份启动的 ...

  8. Android 4.4前后版本读取图库图片和拍照完美解决方案

    转载:http://blog.csdn.net/zbjdsbj/article/details/42387551 4.3或以下,选了图片之后,根据Uri来做处理,很多帖子都有了,我就不详细说了. 主要 ...

  9. MVC中的AppendTrailingSlash以及LowercaseUrls

    asp.net MVC是一个具有极大扩展性的框架,可以在从Url请求开始直到最终的html的渲染之间进行扩展,所以要学好还是需要了解框架的运行原理,推荐Artech. 今天我们回忆的不是MVC中的fi ...

  10. PHP学习笔记三十四【记录日志】

    <?php function my_error2($errno,$errmes) { echo "错误号:".$errno; //默认时区是格林威治相差八个时区 //设置 1 ...