1085: [SCOI2005]骑士精神

Time Limit: 10 Sec  Memory Limit: 162 MB
Submit: 1893  Solved: 1051

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

/*
迭代加深dfs经典题!
记录目标状态,然后从起始状态搜索。
爆搜可能超时,要加剪枝
*/
#include<cstdio>
#include<cstring>
#include<iostream>
#define limit 15
using namespace std;
int T,ans=20,flag;
int xx[9]={0,-2,-2,-1,-1,1,1,2,2};
int yy[9]={0,-1,1,-2,2,2,-2,1,-1};
int s[10][7],get[10][10];
int target[10][10];
char si;void get_t()//记录目标状态
{target[1][1]=1;target[1][2]=1;target[1][3]=1;target[1][4]=1;target[1][5]=1;target[2][1]=0;target[2][2]=1;target[2][3]=1;target[2][4]=1;target[2][5]=1;target[3][1]=0;target[3][2]=0;target[3][3]=2;target[3][4]=1;target[3][5]=1;target[4][1]=0;target[4][2]=0;target[4][3]=0;target[4][4]=0;target[4][5]=1;target[5][1]=0;target[5][2]=0;target[5][3]=0;target[5][4]=0;target[5][5]=0;
}int Judge()//计算当前状态与目标状态至少还有多少步
{int ret=0;for(int i=1;i<=5;i++)for(int j=1;j<=5;j++){if(s[i][j]!=target[i][j])ret++;}return ret;
}void DFS(int now,int x,int y,int sum)
{if(flag) return;int c=Judge();if(now==sum){if(c==0)flag=1,ans=sum;}if(now-1+c>sum) return;//最优性剪枝:当前的步数+差异>限制步数 for(int i=1;i<=8;i++){int nx=x+xx[i];int ny=y+yy[i];if(nx>0&&nx<=5&&ny>0&&ny<=5){swap(s[x][y],s[nx][ny]);DFS(now+1,nx,ny,sum);swap(s[x][y],s[nx][ny]);}}
}int main()
{scanf("%d",&T);get_t();while(T--){int x,y;for(int i=1;i<=5;i++)for(int j=1;j<=5;j++){cin>>si;if(si=='*'){x=i;y=j;get[i][j]=2;}    else get[i][j]=si-'0';}for(int k=0;k<=limit;k++)//迭代加深限制步数
        {flag=0;ans=20;for(int i=1;i<=5;i++)for(int j=1;j<=5;j++)s[i][j]=get[i][j];DFS(0,x,y,k);if(ans==k) break;}if(ans<=15)printf("%d\n",ans);else printf("-1\n");}return 0;
} 

心若向阳,无谓悲伤

转载于:https://www.cnblogs.com/L-Memory/p/6159812.html

bzoj1085骑士精神(搜索)相关推荐

  1. bzoj1085 骑士精神

    骑士精神 题目背景: bzoj1085 分析:迭代加深搜索,每一次枚举走多少步能够到达,每一次搜索当前步数的可行解,判断是否到达最终目标位置,加入剪枝,如果中途发现当前的差异已经大于剩余步数,则表示这 ...

  2. [SCOI2005][BZOJ1085] 骑士精神

    1085: [SCOI2005]骑士精神 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 1112  Solved: 604 [Submit][Sta ...

  3. 【BZOJ1085】【SCOI2005】骑士精神 [A*搜索]

    骑士精神 Time Limit: 10 Sec  Memory Limit: 162 MB [Submit][Status][Discuss] Description 在一个5×5的棋盘上有12个白色 ...

  4. 算法复习——迭代加深搜索(骑士精神bzoj1085)

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

  5. BZOJ1085 [SCOI2005] 骑士精神

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

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

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

  7. bzoj1085: [SCOI2005]骑士精神(a*)

    1085: [SCOI2005]骑士精神 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 2555  Solved: 1472 [Submit][St ...

  8. [启发式搜索/A*] [SCOI2005]骑士精神题解

    洛谷-骑士精神 启发式搜索-A* 估价函数 对于当前状态,我们可以将其与目标状态对比,得到一个预估的代价,即最少(不一定满足题意)的代价,得到这个代价的函数叫做估价函数 对于一个最短路问题来说,我们可 ...

  9. 『骑士精神 IDA*』

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

最新文章

  1. java类加载是什么意思_java 类加载机制有什么用
  2. java 枚举 或运算_Objective-C 枚举 中位运算 的使用
  3. SpringBoot开发最佳实践
  4. jQuery中$(document).ready()和window.onload的区别
  5. python为什么用号做注释符_Python为什么用#号作注释符?
  6. c语言中go的作用,go语言与c语言的相互调用
  7. Android Studio 疑难杂症
  8. VS2017断点调试
  9. MyBatis关键配置
  10. PHP中cookie和session的区别
  11. java 取字符串中的数字_java截取字符串中的数字
  12. __name__ == '__main__'的用法
  13. mysql安装显示3534_MySQL安装成功之后启动错误 3534、28000和简单使用
  14. POJ1657 Bailian1657 Distance on Chessboard【基础】
  15. 搜狐校园“情感分析×推荐排序“算法大赛 AutoX方案 转载poteman
  16. FIT2CLOUD飞致云成为Kubernetes认证服务提供商(KCSP)
  17. Topaz Mask AI for mac(人工智能AI抠图软件) 最新版
  18. matlab模型预测控制基本原理,matlab模型预测控制
  19. 抽象代数之pq阶群或者为循环群或者只有两种结构
  20. gethostbyname linux,gethostbyname()

热门文章

  1. 爬虫实战学习笔记_7 【实战】模拟下载页面视频(模板)
  2. 数据结构之图:加权无向图与寻找最小生成树,Python——27
  3. Express接口综合案例(创建项目、配置常用中间件、路由设计、提取控制器模块、配置错误统一处理中间件、用户注册的数据验证,密码加密)
  4. 使用Node 操作MySQL数据库
  5. 十、关于MySQL 标识列,你该了解这些!
  6. LeetCode 2092. 找出知晓秘密的所有专家(并查集)
  7. LeetCode 1278. 分割回文串 III(区间DP)
  8. 数据结构--跳表SkipList
  9. scrapy使用代理报错keyerror: proxy_爬虫Scrapy框架-Crawlspider链接提取器与规则解析器...
  10. python argument list too long_[已解决]Argument list too long如何处理?