这道题个人认为隐含着状态转换,所以想到的还是BFS,将其中一位数加一或减一或交换临近两位,进入下一状态,使用一个大小为10000的bool数组判重,由于BFS的特性,得到的一定是最小步数;

普通BFS代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<set>
using namespace std;
const int MaxSize = 1e5;
typedef struct node{
int a[4];
int step;
}Node; Node Q[MaxSize]; bool visit[10005]; bool search_table(int *a){
int tmp=0;
tmp = a[0]*1000+a[1]*100+a[2]*10+a[3];
if(visit[tmp])return false;
visit[tmp] = true;
return true;
} int BFS(int *start,int *goal){
int head=0,tail=1,tmp;
memset(visit,0,sizeof(visit));
Node t,s;
memcpy(t.a,start,4*sizeof(int));
t.step = 0;
Q[head] = t;
while(head!=tail){
t = Q[head];
if(!memcmp(t.a,goal,4*sizeof(int))) return t.step;
for(int i=0;i<4;i++){
s = t;
s.a[i]++;
s.step++;
if(s.a[i]>9) s.a[i]=1;
if(search_table(s.a)) {
Q[tail]=s;
tail=(tail+1)%MaxSize;
}
}
for(int i=0;i<4;i++){
s = t;
s.a[i]--;
s.step++;
if(s.a[i]<1) s.a[i]=9;
if(search_table(s.a)) {
Q[tail]=s;
tail=(tail+1)%MaxSize;
}
}
for(int i=0;i<3;i++){
s = t;
tmp = s.a[i],s.a[i] = s.a[i+1],s.a[i+1] = tmp;
s.step++;
if(search_table(s.a)) {
Q[tail]=s;
tail=(tail+1)%MaxSize;
}
}
head=(head+1)%MaxSize;
}
return -1;
} void Input_data(int *start,int *goal){
char c[5];
scanf("%s",c);
for(int i=0;i<4;i++) start[i] = c[i]-'0';
scanf("%s",c);
for(int i=0;i<4;i++) goal[i] = c[i]-'0';
} int main(){
int T,start[4],goal[4];
scanf("%d",&T);
while(T--){
Input_data(start,goal);
printf("%d\n",BFS(start,goal));
}
}

双向BFS:

#include<iostream>
#include<cstdio>
#include<cstring> using namespace std; int visit[10005];
const int MaxSize = 1e5;
typedef struct node{
int a[4],step;
}Node;
Node start,goal;
int trans(Node x){
int tmp = 0;
for(int i=0;i<4;i++) tmp = tmp*10+x.a[i];
//printf("%d\n",tmp);
return tmp;
} Node Q1[MaxSize],Q2[MaxSize]; int BFS(){
memset(visit,0,sizeof(visit));
//queue<Node> Q1,Q2; Node t,s;
int step1=0,step2=0,ans,cnt;
int head1=0,head2=0,tail1=1,tail2=1;
start.step = 0;
goal.step = 0;
Q1[head1] = start;
Q2[head2] = goal;
visit[trans(start)]=1;
visit[trans(goal)]=2;
while(true){
cnt = (tail1-head1+MaxSize)%MaxSize;
while(cnt--){
t = Q1[head1];
if(!memcmp(t.a,goal.a,sizeof(goal.a))) return t.step;
step1 = t.step + 1;
for(int i=0;i<4;i++){
s = t;
s.a[i]++;
if(s.a[i]>9) s.a[i]=1;
ans = trans(s);
if(visit[ans]==2) return step1+step2;
if(!visit[ans]){
visit[ans] = 1;
s.step = step1;
Q1[tail1]=s;
tail1=(tail1+1)%MaxSize;
}
}
for(int i=0;i<4;i++){
s = t;
s.a[i]--;
if(s.a[i]<1) s.a[i]=9;
ans = trans(s);
if(visit[ans]==2) return step1+step2;
if(!visit[ans]){
visit[ans] = 1;
s.step = step1;
Q1[tail1]=s;
tail1=(tail1+1)%MaxSize;
}
}
for(int i=0;i<3;i++){
s = t;
swap(s.a[i],s.a[i+1]);
ans = trans(s);
if(visit[ans]==2) return step1+step2;
if(!visit[ans]){
visit[ans] = 1;
s.step = step1;
Q1[tail1]=s;
tail1=(tail1+1)%MaxSize;
}
}
head1=(head1+1)%MaxSize;
}
cnt = (tail2-head2+MaxSize)%MaxSize;
while(cnt--){
t = Q2[head2];
if(!memcmp(t.a,start.a,sizeof(start.a))) return t.step;
step2 = t.step + 1;
for(int i=0;i<4;i++){
s = t;
s.a[i]++;
if(s.a[i]>9) s.a[i]=1;
ans = trans(s);
if(visit[ans]==1) return step1+step2;
if(!visit[ans]){
visit[ans] = 2;
s.step = step2;
Q2[tail2]=s;
tail2=(tail2+1)%MaxSize;
}
}
for(int i=0;i<4;i++){
s = t;
s.a[i]--;
if(s.a[i]<1) s.a[i]=9;
ans = trans(s);
if(visit[ans]==1) return step1+step2;
if(!visit[ans]){
visit[ans] = 2;
s.step = step2;
Q2[tail2]=s;
tail2=(tail2+1)%MaxSize;
}
}
for(int i=0;i<3;i++){
s = t;
swap(s.a[i],s.a[i+1]);
ans = trans(s);
if(visit[ans]==1) return step1+step2;
if(!visit[ans]){
visit[ans] = 2;
s.step = step2;
Q2[tail2]=s;
tail2=(tail2+1)%MaxSize;
}
}
head2 = (head2+1)%MaxSize;
}
}
}
void Input_and_solve(){
char ch[5];
scanf("%s",ch);
for(int i=0;i<4;i++) start.a[i] = ch[i]-'0';
scanf("%s",ch);
for(int i=0;i<4;i++) goal.a[i] = ch[i]-'0';
printf("%d\n",BFS());
}
int main(){
int T;
scanf("%d",&T);
while(T--){
Input_and_solve();
}
}
//如有错误,还请留言指出

搜索 问题 D: 神奇密码锁的更多相关文章

  1. 《阿里如何实现秒级百万TPS?搜索离线大数据平台大数据平台架构解读》读后感

    在使用淘宝时发现搜索框很神奇,它可以将将我们想要的商品全部查询出来,但是我们并感觉不到数据库查询的过程,速度很快.通过阅读这篇文章让我知道了搜索框背后包含着很多技术,对我以后的学习可能很有借鉴. 平时 ...

  2. POJ2676Sudoku(类似于八皇后)

    Sudoku Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 16444   Accepted: 8035   Special ...

  3. 你所不知道的 URL

    0.说明 第一幕 产品:大叔有用户反映账户不能绑定公众号.大叔:啊咧咧?怎么可能,我看看?大叔:恩?这也没问题啊,魏虾米.大叔:还是没问题啊,挖叉类.大叔:T T,话说产品姐姐是不是Java提供接口的 ...

  4. NOIP练习赛题目3

    魔兽争霸 难度级别:C: 运行时间限制:1000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 小x正在销魂地玩魔兽他正控制着死亡骑士和n个食尸鬼(编号1-n)去打 ...

  5. JS代码静态分析及挖掘

    JavaScript 已经成为现代 Web 浏览器开发中最普遍的技术之一.使用客户端 JavaScript 框架(如 AngularJS,ReactJS 和 Vue.js)构建的应用程序已向前端输送了 ...

  6. 【宽度优先搜索】神奇的状态压缩 CodeVs1004四子连棋

    一.写在前面 其实这是一道大水题,而且还出在了数据最水的OJ上,所以实际上这题并没有什么难度.博主写这篇blog主要是想写下一个想法--状态压缩.状态压缩在记录.修改状态以及判重去重等方面有着极高的( ...

  7. [清华集训2017]小 Y 和地铁(神奇思路,搜索,剪枝,树状数组)

    世界上最不缺的就是好题. 首先考虑暴搜.(还有什么题是从这东西推到正解的……) 首先单独一个换乘站明显没用,只用考虑一对对的换乘站. 那么有八种情况:(从题解偷图)         然后大力枚举每个换 ...

  8. UVA - 1631 Locker(密码锁)(dp---记忆化搜索)

    题意:有一个n(n<=1000)位密码锁,每位都是0~9,可以循环旋转.每次可以让1~3个相邻数字同时往上或者往下转一格.输入初始状态和终止状态(长度不超过1000),问最少要转几次. 分析: ...

  9. 总结oninput、onchange与onpropertychange事件的用法和区别 书写搜索的神奇代码

    总结oninput.onchange与onpropertychange事件的用法和区别 最近手机开发一个模糊搜索的功能组建,在网上就找到这篇文章! 前端页面开发的很多情况下都需要实时监听文本框输入,比 ...

随机推荐

  1. net core 接受post值

    public static string GetPostParams(HttpContext context) { string param = string.Empty; if (context.R ...

  2. 视图:setContentView()

    1.setContentView的作用是将View加载到根view之上,这样当显示view时,先显示根view,然后在显示子view,以此类推,最终将所有view显示出来. 2.setContentV ...

  3. Mysql 获取成绩排序后的名次

    其实就是输出mysql的排序后的行号   RT:获取单个用户的成绩在所有用户成绩中的排名   可以分两步: 1.查出所有用户和他们的成绩排名 ) as rowNo from t_user, () ) ...

  4. 解决运行webpack --config webpack.dev.config.js 报错ReferenceError: _dirname is not defined

    控制台报错信息如下 将webpack.dev.config.js中的_dirname 改为 __dirname 注意这里是两个下划线谢谢!感觉好坑

  5. jq完成省市区街道四级联动

    之前看的省市区街道四级联动的插件,感觉和公司要求的有些不符合,就自己写了一个 因为要读取本地json文件,所以要跑下服务器 下载browser-sync 然后在项目目录下运行browser-sync ...

  6. express 请求参数的一些问题

    先说点别的,项目入口是index.js,运行 node index 启动项目. 路由部分app.get('/', function(req, res) { res.send('hello, expre ...

  7. 高级软件测试技术-任务进度-Day02

    任务进度11-14 使用工具 Jira 小组成员 华同学.郭同学.穆同学.沈同学.覃同学.刘同学 任务进度 在经过了昨天的基本任务分配之后,今天大家就开始了各自的内容,以下是大家任务的进度情况汇总. ...

  8. eclipse连接Mysql和测试

    一.前期准备: 1.eclipse 2.Mysql workbench 3.jdbc 下载地址:https://www.mysql.com/products/connector/ 点击JDBC Dri ...

  9. java内存分布详解

    参见:http://blog.csdn.net/bluetjs/article/details/52874711 基本类型和引用类型.二者作为局部变量,都放在栈中,基本类型直接在栈中保存值,引用类型只 ...

  10. windows程序调试

    由于不能在控制台输出,可以使用Messagebox 但是有时候要用到输出int之类的,需要转换.转换过程中有会有很多问题. 这里给出两个可行的代码 int a = 5, b = 10; int res ...