BZOJ 1085(IDA*)
题面
分析
首先,直接搜索肯定会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*)的更多相关文章
- Booksort POJ - 3460 (IDA*)
Description The Leiden University Library has millions of books. When a student wants to borrow a ce ...
- UVA - 10384 The Wall Pusher(推门游戏)(IDA*)
题意:从起点出发,可向东南西北4个方向走,如果前面没有墙则可走:如果前面只有一堵墙,则可将墙向前推一格,其余情况不可推动,且不能推动游戏区域边界上的墙.问走出迷宫的最少步数,输出任意一个移动序列. 分 ...
- 人类即将进入互联网梦境时代(IDA)
在电影<盗梦空间>中,男主角科布和妻子在梦境中生活了50年,从楼宇.商铺.到河流浅滩.一草一木.这两位造梦师用意念建造了属于自己的梦境空间.你或许并不会想到,在不久未来,这看似科幻的情节将 ...
- [BZOJ 1085][SCOI2005]骑士精神(IDA*)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1085 分析: 首先第一感觉是宽搜,但是空间需要8^15*5*5,明显不够,又鉴于最大深 ...
- 【BZOJ】1085 [SCOI2005]骑士精神(IDA*)
题目 传送门:QWQ 分析 我好菜啊. 一波IDA*水过去了. 代码 #include <bits/stdc++.h> using namespace std; ; char s[maxn ...
- 怒刷BZOJ记录(一)1001~1037
我实在是太弱了...不滚粗只能刷BZOJ了...这里来记录每天刷了什么题吧. 2015-7-9 : 1001[BeiJing2006]狼抓兔子 | 最大流练习(呃..其 ...
- POJ2286 The Rotation Game(IDA*)
The Rotation Game Time Limit: 15000MS Memory Limit: 150000K Total Submissions: 5691 Accepted: 19 ...
- poj2331 (IDA*)
题意:给你k种管道,然后是每种的长度,每种的数量,求(x1,y1)到(x2,y2)所用管道的最少数量 思路: 最开始考虑的是直接bfs,但是没有成功. 然后发现可以先找x轴x1 到 x2 ,再找y轴y ...
- UVA-10384 The Wall Pushers (IDA*)
题目大意:走迷宫,遇到墙时可以推着墙走,但墙后还是墙时便不能推.求出一条任意的最短路径. 题目分析:这道题出的比较人性,输入的时候便是将四周的墙用二进制数表示好了,其实这样减轻了做题人的负担.IDA* ...
随机推荐
- spring动态调用方法
有的时候为了程序的灵活性,需要根据参数动态的调用方法.代码框架大致spring为主,下面是具体代码: 接口: 实现类(实现类中有一个从spring容器中取的对象) 这是最初我直接用反射去调用的代码: ...
- java:Set对象TreeSet有序子类,HashSet无序子类,重复对象二
TreeSet有序子类; HashSet无序子类 重复重复元素,Object对象是通过equals和hashCode来进行过滤的. 如果将上一篇提到中的例子中的TreeSet,换成HashSet,那么 ...
- Linux学习-通过loganalyzer展示MySQL中rsyslog日志
一.实验环境 系统:CentOS7.6 软件包:apache,php,mariadb-server (都是基于光盘yum源) 源码包:loganalyzer-4.1.7.tar.gz (http:// ...
- qt学习(一)qt三个文件函数的框架
学到点什么, 而不是复制着什么, 每天敲着别人给的代码,苦涩得改完bug, 就这样一天天的过去, 实质上并没有学到什么, 别人的思想只是拿来借鉴, 你的思想是好是坏都是你的, 不用急着抛弃自己. 从q ...
- [BZOJ1934][SHOI2007]Vote 善意的投票:最小割
分析 先讲一下连边方法: \(S\)向意愿同意的人,意愿反对的人向\(T\),朋友之间互相连(其实好像意愿不同的朋友之间互相连就可以了,嘛,不管了),容量均为\(1\). 最小割即为答案. 可以理解为 ...
- RabbitMQ幂等性概念(七)
幂等性是什么? 我们可以借鉴数据库的乐观锁机制 比如我们执行一条更新库存的sql语句update user set count=count-1,version=version+1 where vers ...
- leetcode-mid-Linked list- 230 Kth Smallest Element in a BST
mycode 81.40% # Definition for a binary tree node. # class TreeNode(object): # def __init__(self, x ...
- ORACLE Physical Standby 级联备库搭建
搭建oracle 级联DG 现有架构:physical standby 一主二备,在此基础上,在主库下新建备库standby3.级联备库cascade 数据库版本 11.2.0.4 db_name=p ...
- spoj 3267 D-query
题目链接:http://vjudge.net/problem/SPOJ-DQUERY --------------------------------------------------------- ...
- redux源码浅入浅出
运用redux有一段时间了,包括redux-thunk和redux-saga处理异步action都有一定的涉及,现在技术栈转向阿里的dva+antd,好用得不要不要的,但是需要知己知彼要对react家 ...