题目描写叙述:

  历届试题 九宫重排  
时间限制:1.0s   内存限制:256.0MB
      
问题描写叙述
  如以下第一个图的九宫格中,放着 1~8 的数字卡片。另一个格子空着。与空格子相邻的格子中的卡片能够移动到空格中。经过若干次移动。能够形成第二个图所看到的的局面。



  我们把第一个图的局面记为:12345678.

  把第二个图的局面记为:123.46758

  显然是按从上到下,从左到右的顺序记录数字,空格记为句点。

  本题目的任务是已知九宫的初态和终态,求最少经过多少步的移动能够到达。假设不管多少步都无法到达,则输出-1。
输入格式
  输入第一行包括九宫的初态,第二行包括九宫的终态。

输出格式
  输出最少的步数,假设不存在方案,则输出-1。

例子输入
12345678.

123.46758
例子输出
3
例子输入
13524678.

46758123.
例子输出
22

题解: BFS+HASH~~ 第一次用hash,之前一直超时。

代码:

#include<iostream>
#include<cstdio>
char star[10],send[10];
int nodedir=0,exdir=0;
bool visit[200000000]={0};
int dir[4][2]={
{0,1},
{0,-1},
{1,0},
{-1,0},
};
const int Max=200000;
struct Node{
int a[3][3],x,y,step;
} map[Max],temp,end;
int hash(Node x)
{
int num=1,sum=0;
for(int i=0;i<3;i++)
for(int j=0;j<3;j++)
if(x.a[i][j])
{
num=x.a[i][j];
for(int k=0;k<i*3+j;k++)
num*=8;
sum+=num;
}
return sum;
}
int main()
{
scanf("%s%s",star,send);
for(int i=0;i<3;i++)
for(int j=0;j<3;j++)
{
if(star[i*3+j]>'0'&&star[i*3+j]<'9')
map[0].a[i][j]=star[i*3+j]-'0';
else if(star[i*3+j]=='.'){
map[0].a[i][j]=0;
map[0].x=i; map[0].y=j;
}
if(send[i*3+j]>'0'&&send[i*3+j]<'9')
end.a[i][j]=send[i*3+j]-'0';
else{ end.a[i][j]=0;
end.x=i; end.y=j;
}
}
visit[hash(end)]=1;
visit[hash(map[0])]=1;
map[0].step=0;
while(nodedir<=exdir&&exdir<Max)
{
for(int i=0;i<4;i++)
{
temp=map[nodedir];
int dx=temp.x+dir[i][0],dy=temp.y+dir[i][1];
if(dx>=0&&dx<3&&dy>=0&&dy<3)
{
int t;
t=temp.a[temp.x][temp.y];
temp.a[temp.x][temp.y]=temp.a[dx][dy];
temp.a[dx][dy]=t;
temp.x=dx; temp.y=dy; temp.step++;
if(hash(temp)==hash(end))
{
printf("%d\n",temp.step);
return 0;
}
if(!visit[hash(temp)])
map[++exdir]=temp;
visit[hash(temp)]=1;
}
}
nodedir++;
}
printf("-1\n");
return 0;
}

蓝桥杯OJ PREV-19 九宫重排的更多相关文章

  1. 蓝桥杯 历届试题 九宫重排 (bfs+康托展开去重优化)

    Description 如下面第一个图的九宫格中,放着 1~8 的数字卡片,还有一个格子空着.与空格子相邻的格子中的卡片可以移动到空格中.经过若干次移动,可以形成第二个图所示的局面. 我们把第一个图的 ...

  2. 2013年第四届蓝桥杯国赛 九宫重排(HashMap+双BFS优化)

    九宫重排     时间限制:1.0s   内存限制:256.0MB 问题描述 如下面第一个图的九宫格中,放着 1~8 的数字卡片,还有一个格子空着.与空格子相邻的格子中的卡片可以移动到空格中.经过若干 ...

  3. 2019第十届蓝桥杯C++B组题解(赛后重写的,不确保答案正确性,仅供参考)

    先说一下这次的感受吧,我们考场比较乱,开始比赛了,还有的电脑有故障,(向这些人发出同情),第一次认真参加比赛,真正比赛的时候感觉没有那么正式,很乱,各种小问题,(例如博主就没找到题目在哪里,找到后又不 ...

  4. 算法笔记_183:历届试题 九宫重排(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 如下面第一个图的九宫格中,放着 1~8 的数字卡片,还有一个格子空着.与空格子相邻的格子中的卡片可以移动到空格中.经过若干次移动,可以形成 ...

  5. 记 2019蓝桥杯校内预选赛(JAVA组) 赛后总结

    引言 好像博客好久没更新了 哈哈哈哈哈 趁现在有空更新一波 不知道还有没有人看 确实该记录一下每天做了什么了 不然感觉有些浑浑噩噩了 比赛介绍 全称: 蓝桥杯全国软件和信息技术专业人才大赛 蓝桥杯 实 ...

  6. BFS解决九宫重排问题

    问题 1426: [蓝桥杯][历届试题]九宫重排 时间限制: 1Sec 内存限制: 128MB 提交: 215 解决: 47 题目描述 如下面第一个图的九宫格中,放着  1~8  的数字卡片,还有一个 ...

  7. 2012年 蓝桥杯预赛 java 本科 题目

    2012年 蓝桥杯预赛 java 本科 考生须知: l  考试时间为4小时. l  参赛选手切勿修改机器自动生成的[考生文件夹]的名称或删除任何自动生成的文件或目录,否则会干扰考试系统正确采集您的解答 ...

  8. 第六届蓝桥杯软件类省赛题解C++/Java

    第六届蓝桥杯软件类省赛题解C++/Java 1[C++].统计不含4的数字统计10000至99999中,不包含4的数值个数.答:暴力循环范围内所有数字判断一下就是了,答案是52488 1[Java]. ...

  9. 蓝桥杯java历年真题及答案整理1~20.md

    蓝桥杯java历年真题及答案整理(闭关一个月,呕心沥血整理出来的) 1 算法是这样的,如果给定N个不同字符,将这N个字符全排列,最终的结果将会是N!种.如:给定 A.B.C三个不同的字符,则结果为:A ...

随机推荐

  1. 【CF1043C】Smallest Word(构造)

    题意:给定一个由a和b构成的字符串,可以选择翻转或不翻转他的每个前缀,翻转记为1不翻转记为0,求能将字符串排序的字典序最小的操作序列 n<=1e3 思路:考虑极长的一段a [t,w] 翻转t-1 ...

  2. linux下解压zip文件

    linux下解压zip文件 linux自带的unzip命令可以解压windows下的zip格式的压缩文件. unzip命令 语法:unzip [选项] 压缩文件名.zip 各选项的含义分别为: -x ...

  3. 【Visual Studio】解决错误 fatal error C1010: unexpected end of file while looking for precompiled head(转)

    原文转自 http://blog.csdn.net/liuqiyao_01/article/details/38867145 在编译VS时候,出现fatal error C1010: unexpect ...

  4. Django笔记:常见故障排除

    Django框架下MySQLdb模块在python3中无法使用的问题的解决方案 由于python3环境下目前还没有官方的mysqldb模块,Django框架中又强制要求使用mysqldb,为了解决这个 ...

  5. hdu 3879 hdu 3917 构造最大权闭合图 俩经典题

    hdu3879  base station : 各一个无向图,点的权是负的,边的权是正的.自己建一个子图,使得获利最大. 一看,就感觉按最大密度子图的构想:选了边那么连接的俩端点必需选,于是就以边做点 ...

  6. AC日记——[ZJOI2006]物流运输 bzoj 1003

    1003 思路: 最短路+dp: 节点在a-b天里不能使用 那么我们准备每一组a-b求一条最短路,如果没有,则用极大值表示: cost[a,b]记录这个最短路: 然后,开始dp: dp[i]=min( ...

  7. Codeforces Gym100812 L. Knights without Fear and Reproach-扩展欧几里得(exgcd)

    补一篇以前的扩展欧几里得的题,发现以前写错了竟然也过了,可能数据水??? 这个题还是很有意思的,和队友吵了两天,一边吵一边发现问题??? L. Knights without Fear and Rep ...

  8. python-urllib/urllib2模块

    urllib与urllib2: urllib2可以接受一个Request类的实例来设置URL请求的headers,urllib仅可以接受URL.这意味着,你不可以伪装你的User Agent字符串等. ...

  9. java获取整数的各位数值

    第一种是取模运算 int qian =input/1000; //千位除以1000 int bai = input/100%10;//百位除以100%10 int shi = input%100/10 ...

  10. (入门SpringBoot)SpringBoot结合logback(六)

    SpringBoot结合logback日志: 1.配置资源文件: #日志配置信息logbacklogging.config=classpath:logback-spring.xmllog.path=E ...