题目描写叙述 Description

在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且有一个空位。在不论什么时候一个骑士都能依照骑士的走法(它能够走到和它横坐标相差为1。纵坐标相差为2或者横坐标相差为2。纵坐标相差为1的格子)移动到空位上。

给定一个初始的棋盘,如何才干经过移动变成例如以下目标棋盘:

为了体现出骑士精神。他们必须以最少的步数完毕任务。

输入描写叙述 Input Description

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

两组数据之间没有空行。

输出描写叙述 Output Description

对于每组数据都输出一行。

假设能在15步以内(包含15步)到达目标状态,则输出步数。否则输出-1。

例子输入 Sample Input
2
10110
01*11
10111
01001
00000
01011
110*1
01110
01010
00100
例子输出 Sample Output

7

-1

图片不在这儿= =只是看代码就知道了

这是我第一次写IDA* 还是參考了黄学长代码 顺便被罗雨屏神犇好好的歧视了一下 一開始仅仅写了迭代加深搜索 仅仅过了两个点 加了启示式搜索之后过了 事实上这里的估价函数就是里奥神犇当时DFS的剪枝 所以里奥神犇当时写的就已经是IDA*了 ORZ里奥神犇

所谓启示式搜索,就是在搜索过程中加入一个估价函数,代表当前状态到目标状态预估所须要的步数。剪枝就是将不合法的情况去掉。但也能够不剪,优先向估价函数小的方向搜索,在这个方向我们得到正确解期望较大,能够节省时间。

应当注意的是,估价函数仅仅是一个估价。并非实际步数。

假设剪掉估价函数较大的情况,相当于是放弃了一些可能是答案的情况。

但这些情况是答案的可能性较小。

直接上代码吧,关于二维数组的传递。我还不是非常明确。希望大家看了代码帮帮忙

注意这里。二维数组的传递

对于函数的调用是这样写的:

if (ok(&a[0]))
{
flag=true;
}
return;

这个函数声明时,是这种:

bool ok(int (*a)[5])

当中a是一个二维数组。在函数中应用时,直接写a[x][y]就可以

这里a数组我们传递的是地址。由于里奥神犇说。假设传数组的话,数组大了非常可能爆栈。

可是详细为什么要这样写。我也不大明确

原本对于数组a的指针应当是【**a】,可是假设这样写,以下的引用就会各种报错。最后的解决方式就是上面这种。看来我还要慢慢学习啊。

假设有哪位同学懂得二维数组用作实參的传递,请务必告诉我。

——闲梦远,南国正清秋。千里江山寒色远,芦花深处泊孤舟。笛在月明楼。

【日常学习】【IDA*】codevs2449 骑士精神题解的更多相关文章

  1. BZOJ1085:[SCOI2005]骑士精神——题解+IDA*粗略讲解

    http://www.lydsy.com/JudgeOnline/problem.php?id=1085 Description 在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且有一个空 ...

  2. codevs2449 骑士精神

    题目描述 Description 在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且有一个空位.在任何时候一个骑士都能按照骑士的走法(它可以走到和它横坐标相差为1,纵坐标相差为2或者横坐标 ...

  3. IDA*算法——骑士精神

    例题 骑士精神 Description 在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且有一个空位.在任何时候一个骑士都能按照骑士的走法(它可以走到和它横坐标相差为1,纵坐标相差为2或者 ...

  4. BZOJ1085 luogu2324骑士精神题解

    没有什么特别好的办法,只好用搜索去做 因为一次移动最多归位一个骑士 所以可以想到用IDA*,为了简化状态 我们用k,x,y,sum来表示移动了k步,空格在x,y,还用sum个没有归位的情况 然后枚举转 ...

  5. 【日常学习】codevs1287 矩阵乘法题解

    转载请注明出处 [ametake版权全部]http://blog.csdn.net/ametake欢迎来看. 先上题目 题目描写叙述 Description 小明近期在为线性代数而头疼,线性代数确实非 ...

  6. 埃及分数&&The Rotation Game&&骑士精神——IDA*

    IDA*:非常好用的搜索,可以解决很多深度浅,但是规模大的搜索问题. 估价函数设计思路:观察一步最多能向答案靠近多少. 埃及分数 题目大意: 给出一个分数,由分子a 和分母b 构成,现在要你分解成一系 ...

  7. 【洛谷2324】[SCOI2005]骑士精神 IDA*

    [SCOI2005]骑士精神 描述 在一个\(5×5\)的棋盘上有\(12\)个白色的骑士和\(12\)个黑色的骑士, 且有一个空位.在任何时候一个骑士都能按照骑 士的走法(它可以走到和它横坐标相差为 ...

  8. 『骑士精神 IDA*』

    骑士精神(SCOI2005) Description 在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且有一个空位.在任何时候一个骑士都能按照骑 士的走法(它可以走到和它横坐标相差为1,纵 ...

  9. 1085. [SCOI2005]骑士精神【IDA※】

    Description 在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且有一个空位.在任何时候一个骑士都能按照骑 士的走法(它可以走到和它横坐标相差为1,纵坐标相差为2或者横坐标相差为2 ...

随机推荐

  1. linux-cp

    cp 更改时间: 2017-10-26 - 21:00:54 cp:用来复制文件或者目录的命令,当源文件与目标文件名字相同的时候,当cp 没有参数,源文件会覆盖目标文件 参数 -p:保留源文件或者目录 ...

  2. 用cmd命令创建oracle 数据库、用户和表空间

    Win+R调查运行窗口,输入cmd回车 连接到本地oracle库 创建名为"SXSJ"的表空间,其初始大小为512M,支持自动扩展,每次增量为32M: create tablesp ...

  3. 532. K-diff Pairs in an Array

    Given an array of integers and an integer k, you need to find the number of unique k-diff pairs in t ...

  4. 谈谈我的移动端rem适配方案

    最近有点怀疑人生,毕竟一个人写前端,有时候会怀疑自己理解的一些东西包括用法有没有符合标准.趁着这阵子闲下来,翻了翻别人的rem适配博客,发现有点绕口,怪自己是个强迫症,啥都要自己去试试结果并从中理解, ...

  5. 72、django之简单验证码实现与form表单钩子函数补充

    本篇主要讲解简单的验证码实现,验证码使用基本都是找现成的组件来实现,用代码实现这个简单功能主要是了解了解验证码内部的实现. 本篇导航: 五位验证码图示 代码实现 登录验证 Form组件钩子函数补充 一 ...

  6. 最全Jenkins+SVN+iOS+cocoapods环境搭建及其错误汇总

    前言 持续集成是敏捷开发中重要的一部分,为保证新功能的开发,又保证旧功能的维护,从一个冲刺到下个冲刺.持续集成工具是我们保证开发和维护并行的护航者,现在流行的集成工具有很多,例如: 1.Jenkins ...

  7. TCP:传输控制协议

    概述: 书中采用了8章来介绍TCP,可见其重要性.TCP是一种面向连接的.可靠的字节流服务,也就是说两方要交换数据必须先建立一个连接. TCP的信息单位称为segment.TCP对字节流的内容不作任何 ...

  8. JDK自带VM分析工具jps,jstat,jmap,jconsole

    一.概述 SUN 的JDK中的几个工具,非常好用.秉承着有免费,不用商用的原则.以下简单介绍一下这几种工具.(注:本文章下的所有工具都存在JDK5.0以上版本的工具集里,同javac一样,不须特意安装 ...

  9. CathyCMS-后台管理v1.0

    摘要: 最近开发CathyCMS系统作为练手项目,后台管理部分v1.0暂时告一段落.目前只包含了基本的登录.权限管理.频道管理.文章管理功能. 项目地址: https://github.com/cat ...

  10. HTML5学习指导路线

    HTML5是现在热门的技术,经过8年的艰苦努力,该标准规范终于制定完成,在这里为想要学习HTML5初级程序员详细划分一下学习内容和步骤,让大家清楚的知道HTML5需要学什么?能够快速掌握HTML5开发 ...