题面

传送门

分析

首先,直接搜索肯定会TLE
很容易想到用迭代加深的方法,限定搜索深度
但是,这样仍然不够,需要用启发式的方法优化
我们设计一个估价函数f(x)=g(x)+h(x)f(x)=g(x)+h(x)
g(x)g(x)是初始状态到当前状态的实际代价
h(x)h(x)是当前到目标的估计代价
如果f(x)=g(x)+h(x)>d(当前限定深度)f(x)=g(x)+h(x)>d(当前限定深度),则直接返回
h(x)h(x)函数如何设计?
h(x)h(x)不能劣于实际最优值,所以可设为当前状态与目标状态不同方格的数量

代码

#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 16
using namespace std;
int n=5;
int walkx[10]= {1,1,-1,-1,2,2,-2,-2};
int walky[10]= {2,-2,2,-2,1,-1,1,-1};
char now[maxn][maxn];
char final[maxn][maxn]= {{},{' ','1','1','1','1','1'},{' ','0','1','1','1','1'},{' ','0','0','*','1','1'},{' ','0','0','0','0','1'},{' ','0','0','0','0','0'}};
int is_same() {
for(int i=1; i<=n; i++) {
for(int j=1; j<=n; j++) {
if(now[i][j]!=final[i][j]) return 0;
}
}
return 1;
}
int h() { //估价函数
int cnt=0;
for(int i=1; i<=n; i++) {
for(int j=1; j<=n; j++) {
if(now[i][j]!=final[i][j]) cnt++;
}
}
return cnt;
}
int ida(int deep,int limit,int x,int y) {
// printf("%d %d %d %d\n",deep,dasadfslimit,x,y);
// for(int i=1; i<=n; i++) {
// for(int j=1; j<=n; j++) {
// printf("%c",now[i][j]);
// }
// printf("\n");
// }
// printf("\n");
if(deep>limit) return 0;
if(deep==limit) {
if(is_same()) {
// for(int i=1; i<=n; i++) {
// for(int j=1; j<=n; j++) {
// printf("%c",now[i][j]);
// }
// printf("\n");
// }
return 1;
} else return 0;
}
int flag=0;
for(int i=0; i<8; i++) {
int xx=x+walkx[i],yy=y+walky[i];
if(xx<1||yy<1||xx>n||yy>n) continue;
swap(now[x][y],now[xx][yy]);
if(deep+h()<=limit) flag|=ida(deep+1,limit,xx,yy);
swap(now[x][y],now[xx][yy]);
}
return flag;
}
int t;
int main() {
scanf("%d",&t);
while(t--) {
int sx,sy;
for(int i=1; i<=5; i++) {
for(int j=1; j<=5; j++) {
cin>>now[i][j];
if(now[i][j]=='*') {
sx=i;
sy=j;
}
}
}
// for(int i=1; i<=n; i++) {
// for(int j=1; j<=n; j++) {
// printf("%c",final[i][j]);
// }
// printf("\n");
// }
for(int i=0; i<=16; i++) {
if(i==16) {
printf("-1\n");
break;
}
if(ida(0,i,sx,sy)) {
printf("%d\n",i);
break;
}
}
}
}

BZOJ 1085(IDA*)的更多相关文章

  1. Booksort POJ - 3460 (IDA*)

    Description The Leiden University Library has millions of books. When a student wants to borrow a ce ...

  2. UVA - 10384 The Wall Pusher(推门游戏)(IDA*)

    题意:从起点出发,可向东南西北4个方向走,如果前面没有墙则可走:如果前面只有一堵墙,则可将墙向前推一格,其余情况不可推动,且不能推动游戏区域边界上的墙.问走出迷宫的最少步数,输出任意一个移动序列. 分 ...

  3. 人类即将进入互联网梦境时代(IDA)

    在电影<盗梦空间>中,男主角科布和妻子在梦境中生活了50年,从楼宇.商铺.到河流浅滩.一草一木.这两位造梦师用意念建造了属于自己的梦境空间.你或许并不会想到,在不久未来,这看似科幻的情节将 ...

  4. [BZOJ 1085][SCOI2005]骑士精神(IDA*)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1085 分析: 首先第一感觉是宽搜,但是空间需要8^15*5*5,明显不够,又鉴于最大深 ...

  5. 【BZOJ】1085 [SCOI2005]骑士精神(IDA*)

    题目 传送门:QWQ 分析 我好菜啊. 一波IDA*水过去了. 代码 #include <bits/stdc++.h> using namespace std; ; char s[maxn ...

  6. 怒刷BZOJ记录(一)1001~1037

    我实在是太弱了...不滚粗只能刷BZOJ了...这里来记录每天刷了什么题吧. 2015-7-9 : 1001[BeiJing2006]狼抓兔子                 | 最大流练习(呃..其 ...

  7. POJ2286 The Rotation Game(IDA*)

    The Rotation Game Time Limit: 15000MS   Memory Limit: 150000K Total Submissions: 5691   Accepted: 19 ...

  8. poj2331 (IDA*)

    题意:给你k种管道,然后是每种的长度,每种的数量,求(x1,y1)到(x2,y2)所用管道的最少数量 思路: 最开始考虑的是直接bfs,但是没有成功. 然后发现可以先找x轴x1 到 x2 ,再找y轴y ...

  9. UVA-10384 The Wall Pushers (IDA*)

    题目大意:走迷宫,遇到墙时可以推着墙走,但墙后还是墙时便不能推.求出一条任意的最短路径. 题目分析:这道题出的比较人性,输入的时候便是将四周的墙用二进制数表示好了,其实这样减轻了做题人的负担.IDA* ...

随机推荐

  1. springboot easyexcel

    pom..xml <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel&l ...

  2. MyEclipse使用教程:使用Workbench和Perspectives

    [MyEclipse CI 2019.4.0安装包下载] workbench指的是加载IDE时看到的内容,它通常包含一个perspective,这是相关视图和编辑器的布局.您可以根据正在进行开发的类型 ...

  3. BSOJ5467 [CSPX2017#3]整数 莫比乌斯反演+杜教筛

    题意简述 给你两个整数\(n\),\(k\),让你求出这个式子 \[ \sum_{a_1=1}^n \sum_{a_2=a_1}^n \sum_{a_3=a_2}^n \cdots \sum_{a_k ...

  4. ESP8266-利用网页控制ESP8266

    说明:发出/gpio/1   就输出 "亮灯":   /gpio/0  就输出 "灭灯"  #include <ESP8266WiFi.h> con ...

  5. 用电脑Python控制Arduino

    python指令: import serial #导入串口通讯库 import time ser=serial.Serial("com4",9600,timeout=1) demo ...

  6. 《转》tensorflow学习笔记

    from http://m.blog.csdn.net/shengshengwang/article/details/75235860 1. RNN结构 解析: (1)one to one表示单输入单 ...

  7. C# 实现二维数组的排序算法(代码)

    class Order { /// <summary> /// 对二维数组排序 /// </summary> /// <param name="values&q ...

  8. 使用IDEA连接mysql数据库

    1.IDEA配置数据库连接 2.添加数据库: 3.填写数据库信息: database输入框里面填写要连接的数据库名称 然后点击test connection,会弹出一个框,提示下载驱动,点击进行下载即 ...

  9. node创建项目,要ejs模板引擎,不要jade怎么办?

    创建项目时:express ejs blog,生成的是.jade文件怎么办?我想要的是ejs的呀 上述语句不仅名字不对,生成文件的格式也不是我想要的. 不妨试试:express -e blog 这下就 ...

  10. php reset()函数 语法

    php reset()函数 语法 作用:将内部指针指向数组中的第一个元素,并输出.博智达 语法:reset(array) 参数: 参数 描述 array  必需.规定要使用的数组. 说明:若成功则返回 ...