题目大意:略

每次选择一个最大深度K,跑IDA*

估价函数H=8-中间8个格里出现次数最多的数的个数x,即把它填满这个数最少需要8-x次操作,如果dep+H>K,就跳出..

深搜的时候暴力修改,记录操作的方向,回溯再改回来就行了,根本不用把网格压进状态里嘛..

又水了一篇博客

#include <queue>
#include <cstdio>
#include <cstring>
#include <algorithm>
#define NN 2010
#define ll long long
#define uint unsigned int
#define ull unsigned long long
#define inf 0x3f3f3f3f
using namespace std; int ans[NN];
int mp[][],tmp[];
int xx[]={,,,,,,,,,,,,,,,,,,,,,,,};
int yy[]={,,,,,,,,,,,,,,,,,,,,,,,};
int sum[],op[NN],num;
int esti()
{
int x,y;
sum[]=sum[]=sum[]=;
x=xx[],y=yy[],sum[mp[x][y]]++;
x=xx[],y=yy[],sum[mp[x][y]]++;
x=xx[],y=yy[],sum[mp[x][y]]++;
x=xx[],y=yy[],sum[mp[x][y]]++;
x=xx[],y=yy[],sum[mp[x][y]]++;
x=xx[],y=yy[],sum[mp[x][y]]++;
x=xx[],y=yy[],sum[mp[x][y]]++;
x=xx[],y=yy[],sum[mp[x][y]]++;
return -max(sum[],max(sum[],sum[]));
}
void A(){
for(int i=;i<;i++)
mp[i][]=mp[i+][];
mp[][]=mp[][],mp[][]=;
}
void B(){
for(int i=;i<;i++)
mp[i][]=mp[i+][];
mp[][]=mp[][],mp[][]=;
}
void C(){
for(int i=;i>;i--)
mp[][i]=mp[][i-];
mp[][]=mp[][],mp[][]=;
}
void D(){
for(int i=;i>;i--)
mp[][i]=mp[][i-];
mp[][]=mp[][],mp[][]=;
}
void E(){
for(int i=;i>;i--)
mp[i][]=mp[i-][];
mp[][]=mp[][],mp[][]=;
}
void F(){
for(int i=;i>;i--)
mp[i][]=mp[i-][];
mp[][]=mp[][],mp[][]=;
}
void G(){
for(int i=;i<;i++)
mp[][i]=mp[][i+];
mp[][]=mp[][],mp[][]=;
}
void H(){
for(int i=;i<;i++)
mp[][i]=mp[][i+];
mp[][]=mp[][],mp[][]=;
} int dfs(int dep,int ma)
{
if(esti()==) return mp[][];
if(dep>=ma) return ;
if(esti()>ma-dep) return ;
int ans;
A();ans=dfs(dep+,ma);F();
if(ans){op[++num]=;return ans;}
B();ans=dfs(dep+,ma);E();
if(ans){op[++num]=;return ans;}
C();ans=dfs(dep+,ma);H();
if(ans){op[++num]=;return ans;}
D();ans=dfs(dep+,ma);G();
if(ans){op[++num]=;return ans;}
E();ans=dfs(dep+,ma);B();
if(ans){op[++num]=;return ans;}
F();ans=dfs(dep+,ma);A();
if(ans){op[++num]=;return ans;}
G();ans=dfs(dep+,ma);D();
if(ans){op[++num]=;return ans;}
H();ans=dfs(dep+,ma);C();
if(ans){op[++num]=;return ans;}
return ;
} int a[];
int main()
{
//freopen("t2.in","r",stdin);
while(scanf("%d",&a[])&&a[]!=)
{
ull S=;num=;
mp[xx[]][yy[]]=a[];
for(int i=;i<;i++){
scanf("%d",&a[i]);
mp[xx[i]][yy[i]]=a[i];
}
int ans;
ans=dfs(,);
if(ans){
printf("No moves needed\n%d\n",ans);
continue;
}
for(int k=;k<=;k++){
ans=dfs(,k);
if(ans){
for(int i=num;i>=;i--)
printf("%c",op[i]+'A'-);
puts("");
printf("%d\n",ans);
break;
}
}
}
return ;
}

HDU 1667 The Rotation Game (A*迭代搜索)的更多相关文章

  1. hdu 1667 The Rotation Game ( IDA* )

    题目大意: 给你一个“井”子状的board,对称的由24个方块组成,每个方块上有123三个数字中的一个.给你初始状态,共有八种变换方式,求字典序最小的最短的的变换路径使得,board中间的八个方块上数 ...

  2. IDA*、操作打表、并行处理-The Rotation Game HDU - 1667

    万恶之源 优秀题解 用文字终究难以穷尽代码的思想 思路 每次操作都有八种选择,相当于一棵每次延申八个子节点的搜索树,故搜索应该是一种方法.而这题要求求最少步数,我们就可以想到可以试试迭代加深搜索(但其 ...

  3. HUD 1043 Eight 八数码问题 A*算法 1667 The Rotation Game IDA*算法

    先是这周是搜索的题,网站:http://acm.hdu.edu.cn/webcontest/contest_show.php?cid=6041 主要内容是BFS,A*,IDA*,还有一道K短路的,.. ...

  4. hdu 1667(IDA*)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1667 思路:大牛说是IDA*的入门题=.=构造h()=8-max(1,2,3);  max(1,2,3 ...

  5. 【HDOJ】1667 The Rotation Game

    1. 题目描述有个#字型的条带,可以从横线或竖线进行循环移动,求通过各种移动最终使中心的8个字符全等的长度最短并相同长度字典序最小的操作序列.2. 基本思路24个数据,8种移动方式,数据量很小了,所以 ...

  6. 【学时总结】 ◆学时·II◆ IDA*算法

    [学时·II] IDA*算法 ■基本策略■ 如果状态数量太多了,优先队列也难以承受:不妨再回头看DFS-- A*算法是BFS的升级,那么IDA*算法是对A*算法的再优化,同时也是对迭代加深搜索(IDF ...

  7. HDU 4708:Rotation Lock Puzzle

    Rotation Lock Puzzle Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Oth ...

  8. HDU 4708 Rotation Lock Puzzle(模拟)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4708 题目大意:给定一个方形矩阵,边长为3-10的奇数.每一圈的数字可以沿着顺时针方向和逆时针方向旋转 ...

  9. POJ 2286 The Rotation Game 迭代搜索深度 + A* == IDA*

    感觉这样的算法还是比較局限的吧,反复搜索是一个不好的地方,并且须要高效的估值函数来进行强剪枝,这点比較困难. 迭代搜索深度是一个比較炫酷的搜索方式,只是有点拿时间换空间的感觉. 首先迭代深度比較搓的写 ...

随机推荐

  1. CDR入门教程-CorelDRAW排版教程

    CorelDRAW是一个绘制矢量图,排版的软件.今天给大家带来一片教程就是关于排版的.大家快来试试吧. CDR下载:http://pan.baidu.com/s/1cD4buQ 步骤一:新建一个A4文 ...

  2. 实验楼—Mysql—查找最爱学的课程

    转载:https://www.shiyanlou.com/challenges/2651 背景 从上节题目构建的课程数据库中提取每个用户最爱学的课程数据. 右边桌面是实验楼的服务器,服务器中的 MyS ...

  3. 算法21----重塑矩阵 LeetCode566

    1.题目 在MATLAB中,有一个非常有用的函数 reshape,它可以将一个矩阵重塑为另一个大小不同的新矩阵,但保留其原始数据. 给出一个由二维数组表示的矩阵,以及两个正整数r和c,分别表示想要的重 ...

  4. C语言基本语法——数组

    一.一维数组 1.什么是数组 2.数组语法 3.下标 4.初始化 5.数组名和数组首地址 二.一维数组的应用 1.数组的赋值与拷贝 2.数组的正反遍历 3.随机数 4.数组乱序 5.数组的重复 三.二 ...

  5. [置顶] 使用 maven 插件 maven-shade-plugin 对可执行 java 工程及其全部依赖 jar 进行打包

    作者:chenzhou123520 出处:http://chenzhou123520.iteye.com/blog/1706242 使用 maven 插件 maven-shade-plugin 对 j ...

  6. u-boot启动代码start.S详解

    (1)定义入口.由于一个可执行的Image必须有一个入口点,并且只能有一个全局入口,通常这个入口放在ROM(Flash)的0x0地址,因此,必须通知编译器以使其知道这个入口,该工作可通过修改连接器脚本 ...

  7. 递归树处理,配合vue的vueTreeselect组件使用

    在项目中经常会使用到tree,并且需要对递归树进行操作. 在vue项目中,使用vue-treeselect插件(https://vue-treeselect.js.org/) 使用中遇到的问题: 1. ...

  8. js-DOM操作基本知识

  9. freemark实现遍历 list,每行三个

    我的做法是先做一个模板,这三个只都是从list里取出来的 在后台将每三个值放到一个map里 List<Map<String, Object>> newsList=new Arr ...

  10. C++链接和执行相关错误

    http://blog.csdn.net/pipisorry/article/details/37610401 LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文 ...