题目:

Description

  在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且有一个空位。在任何时候一个骑士都能按照骑
士的走法(它可以走到和它横坐标相差为1,纵坐标相差为2或者横坐标相差为2,纵坐标相差为1的格子)移动到空
位上。 给定一个初始的棋盘,怎样才能经过移动变成如下目标棋盘: 为了体现出骑士精神,他们必须以最少的步
数完成任务。

Input

  第一行有一个正整数T(T<=10),表示一共有N组数据。接下来有T个5×5的矩阵,0表示白色骑士,1表示黑色骑
士,*表示空位。两组数据之间没有空行。

Output

  对于每组数据都输出一行。如果能在15步以内(包括15步)到达目标状态,则输出步数,否则输出-1。

Sample Input

2
10110
01*11
10111
01001
00000
01011
110*1
01110
01010
00100

Sample Output

7
-1

题解:

首先说一下迭代加深搜索:

迭代加深搜索是搜索算法的一种优化方式,具体方法为在知道搜索最大深度的情况下(如题目中最多15步)从低到高枚举搜索深度上界,则第一个满足的枚举深度就一定是最浅深     度即最优解,另外为了更好的优化,还可以构造一个预估函数,即当前搜索状态到满足题意状态至少要用多少步(注意该函数宁愿估小也不要估大否则可能发生错误),如果当前     搜索深度加上预估函数的值都大于枚举深度那肯定也不满足;

迭代加深搜索适用于便于预估所有状态下搜索上界的情况,且搜索深度不大的情况;

不懂的话结合这道题和代码理解即可;

代码:

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<ctime>
#include<cctype>
#include<cstring>
#include<string>
#include<algorithm>
using namespace std;
const char goal[][]={{'','','','',''},
{'','','','',''},
{'','','*','',''},
{'','','','',''},
{'','','','',''}};
int sx,sy,T,step;
char map[][];
struct node
{
int gox;
int goy;
}go[];
inline void pre()
{
go[].gox=,go[].goy=;
go[].gox=,go[].goy=-;
go[].gox=,go[].goy=;
go[].gox=,go[].goy=-;
go[].gox=-,go[].goy=;
go[].gox=-,go[].goy=-;
go[].gox=-,go[].goy=;
go[].gox=-,go[].goy=-;
}
inline bool jud(int x,int y)
{
return x>=&&x<=&&y>=&&y<=;
}
inline int check()
{
int dif=;
for(int i=;i<=;i++)
for(int j=;j<=;j++)
if(map[i][j]!=goal[i][j]) dif++;
return dif;
}
inline bool dfs(int x,int y,int now)
{
if(now==step+)
{
if(check()==) return true;
else return false;
}
if(now+check()->step) return false;
for(int i=;i<=;i++)
{
int tx=x+go[i].gox;
int ty=y+go[i].goy;
if(jud(tx,ty))
{
swap(map[x][y],map[tx][ty]);
if(dfs(tx,ty,now+)) return true;
swap(map[x][y],map[tx][ty]);
}
}
return false;
}
int main()
{
//freopen("a.in","r",stdin);
scanf("%d",&T);
pre();
while(T--)
{
sx=sy=;
for(int i=;i<=;i++)
scanf("%s",map[i]);
bool flag=false;
for(int i=;i<=;i++)
{
if(flag==true) break;
for(int j=;j<=;j++)
if(map[i][j]=='*')
{
sx=i,sy=j;
flag=true;
break;
}
}
step=;
for(int i=;i<=;i++)
{
if(dfs(sx,sy,)) break;
step++;
}
if(step==) cout<<"-1"<<endl;
else cout<<step<<endl;
}
return ;
}

算法复习——迭代加深搜索(骑士精神bzoj1085)的更多相关文章

  1. BZOJ1085: [SCOI2005]骑士精神 [迭代加深搜索 IDA*]

    1085: [SCOI2005]骑士精神 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1800  Solved: 984[Submit][Statu ...

  2. 【bzoj1085】【 [SCOI2005]骑士精神】启发式剪枝+迭代加深搜索

    (上不了p站我要死了,侵权度娘背锅) 如果这就是启发式搜索的话,那启发式搜索也不是什么高级玩意嘛..(啪啪打脸) Description 在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且 ...

  3. BZOJ 1085 骑士精神 迭代加深搜索+A*

    题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1085 题目大意: 在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且有一个 ...

  4. BZOJ.1085.[SCOI2005]骑士精神(迭代加深搜索)

    题目链接 最小步数这类,适合用迭代加深搜索. 用空格走代替骑士. 搜索时记录上一步防止来回走. 不需要每次判断是否都在位置,可以计算出不在对应位置的骑士有多少个.而且每次复原一个骑士至少需要一步. 空 ...

  5. 迭代加深搜索 C++解题报告 :[SCOI2005]骑士精神

    题目 此题根据题目可知是迭代加深搜索. 首先应该枚举空格的位置,让空格像一个马一样移动. 但迭代加深搜索之后时间复杂度还是非常的高,根本过不了题. 感觉也想不出什么减枝,于是便要用到了乐观估计函数(O ...

  6. 【算法•日更•第三十九期】迭代加深搜索:洛谷SP7579 YOKOF - Power Calculus 题解

    废话不多说,直接上题: SP7579 YOKOF - Power Calculus 题意翻译 (略过没有营养的题干) 题目大意: 给出正整数n,若只能使用乘法或除法,输出使x经过运算(自己乘或除自己, ...

  7. A*算法详解 BZOJ 1085骑士精神

    转载1:A*算法入门 http://www.cppblog.com/mythit/archive/2009/04/19/80492.aspx 在看下面这篇文章之前,先介绍几个理论知识,有助于理解A*算 ...

  8. UVA11212-Editing a Book(迭代加深搜索)

    Problem UVA11212-Editing a Book Accept:572  Submit:4428 Time Limit: 10000 mSec  Problem Description ...

  9. 7-10Editing aBook uva11212(迭代加深搜索 IDA*)

    题意:  给出n( 2<=n<=9) 个乱序的数组  要求拍成升序  每次 剪切一段加上粘贴一段算一次  拍成1 2 3 4 ...n即可     求排序次数 典型的状态空间搜索问题   ...

随机推荐

  1. jmeter中通过jdbc方式连接mysql数据库的配置参考

    jmeter中通过jdbc方式连接mysql数据库的配置参考: Database URL=jdbc:mysql://ip:port/dbname?useUnicode=true&allowMu ...

  2. 0x00000124蓝屏问题解决方法

    windows7-32位系统: 0x00000124蓝屏是系统问题,win7才有的, xp系统没有 . 解决办法:下载win7蓝屏补丁包解压安装就ok了. 说明:win7蓝屏补丁KB(25286140 ...

  3. HDU 4347 The Closest M Points (kdTree)

    赤果果的kdTree. 学习传送门:http://www.cnblogs.com/v-July-v/archive/2012/11/20/3125419.html 其实就是二叉树的变形 #includ ...

  4. java.sql.SQLException: Incorrect string value: '\xE6\x88\x91\xE7\x9A\x84...' for column 'groupName'

    java.sql.SQLException: Incorrect string value: '\xE6\x88\x91\xE7\x9A\x84...' for column 'groupName' ...

  5. win7上安装虚拟机并上网

    一.安装Workstation Pro 二.下载CentOS-7-x86_64-DVD-1511.iso包 三.创建新的虚拟机,按照向导安装即可 四.使用cd /etc/sysconfig/netwo ...

  6. Bootstrap 静态控件

    当您需要在一个水平表单内表单标签后放置纯文本时,请在 <p> 上使用 class .form-control-static. 实例: <!DOCTYPE html><ht ...

  7. Bootstrap 网格系统(Grid System)实例2

    Bootstrap 网格系统(Grid System):堆叠水平,两种样式 <!DOCTYPE html><html><head><meta http-equ ...

  8. shell脚本,批量创建10个系统帐号并设置密码为随机8位字符串。

    [root@localhost wyb]# cat user10.sh #!/bin/bash #批量创建10个系统帐号wangyb01-wangyb10并设置密码(密码为随机8位字符串). > ...

  9. tkinter学习-选择按钮

    阅读目录 Checkbutton Radiobutton LabelFrame checkbutton : 说明:多选框控件,用于在程序中提供多项选择框,但是处理“多选一”的问题,还是交给 Radio ...

  10. laravel使用总结(二)

    Mysql Eloquent 模型 新建Model 对应 表前缀 + 类名称 + s namespace App; use Illuminate\Database\Eloquent\Model; cl ...