POJ2286 The Rotation Game(IDA*)
The Rotation Game
Time Limit: 15000MS |
Memory Limit: 150000K |
|
Total Submissions: 5691 |
Accepted: 1918 |
Description
The rotation game uses a # shaped board, which can hold 24 pieces of square blocks (see Fig.1). The blocks are marked with symbols 1, 2 and 3, with exactly 8 pieces of each kind.
Initially, the blocks are placed on the board randomly. Your task is to move
the blocks so that the eight blocks placed in the center square have the same
symbol marked. There is only one type of valid move, which is to rotate one of
the four lines, each consisting of seven blocks. That is, six blocks in the
line are moved towards the head by one block and the head block is moved to the
end of the line. The eight possible moves are marked with capital letters A to
H. Figure 1 illustrates two consecutive moves, move A and move C from some
initial configuration.
Input
The input consists of no more than 30 test cases. Each
test case has only one line that contains 24 numbers, which are the symbols of
the blocks in the initial configuration. The rows of blocks are listed from top
to bottom. For each row the blocks are listed from left to right. The numbers
are separated by spaces. For example, the first test case in the sample input
corresponds to the initial configuration in Fig.1. There are no blank lines
between cases. There is a line containing a single `0' after the last test case
that ends the input.
Output
For each test case, you must output two lines. The first
line contains all the moves needed to reach the final configuration. Each move
is a letter, ranging from `A' to `H', and there should not be any spaces
between the letters in the line. If no moves are needed, output `No moves
needed' instead. In the second line, you must output the symbol of the blocks
in the center square after these moves. If there are several possible
solutions, you must output the one that uses the least number of moves. If
there is still more than one possible solution, you must output the solution
that is smallest in dictionary order for the letters of the moves. There is no
need to output blank lines between cases.
Sample Input
1 1 1 1 3 2 3 2 3 1 3 2 2 3 1 2 2 2 3 1 2 1 3 3
1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 3 3 3 3 3 3 3 3
0
Sample Output
AC
2
DDHH
2
Source
【思路】
IDA*算法。
IDA*=ID-DFS+A*,即不断加深搜索的深度并设计一个乐观估计函数进行剪枝。
应用与本题中;
乐观估计:设中心8个数字最小不相同的数目为h,则至少需要dep+h个操作才能使得满足条件(dep为当前深度)。
迭代加深:不断增加操作数的数目,只要有符合的则中断迭代。
参考了紫书的附加代码,其中的hash有效简化了程序。
【代码】
#include<cstdio>
#include<string>
#include<cstring>
#include<vector>
#include<iostream>
#define FOR(a,b,c) for(int a=(b);a<(c);a++)
using namespace std; int hash[][]={
{,,,,,,},
{,,,,,,},
{,,,,,,},
{,,,,,,} };
const int rev[]={,,,,,,,};
const int certain[]={,,,,,,,}; int a[];
char ans[]; int diff(int c) {
int cnt=;
FOR(i,,) if(c!=a[certain[i]]) cnt++;
return cnt;
} int h() {
return min(min(diff(),diff()),diff());
} bool is_final() {
FOR(i,,) if(a[certain[]]!=a[certain[i]]) return false;
return true;
} void move(int i) {
int tmp=a[hash[i][]];
FOR(j,,) a[hash[i][j]]=a[hash[i][j+]];
a[hash[i][]]=tmp;
} bool IDDFS(int dep,int max_d) {
if(is_final()) {
ans[dep] = '\0';
cout<<ans<<"\n";
return true;
}
if(dep+h()>max_d) return false;
FOR(i,,) {
ans[dep] = 'A'+i;
move(i);
if(IDDFS(dep+,max_d)) return true;
move(rev[i]);
}
return false;
} int main()
{
FOR(i,,) {
FOR(j,,) hash[i][j]=hash[rev[i]][-j];
}
while(scanf("%d",&a[]) && a[])
{
FOR(i,,) scanf("%d",&a[i]);
FOR(i,,) if(!a[i]) return ;
if(is_final())
printf("No moves needed\n");
else {
for(int max_d=; ;max_d++)
if(IDDFS(,max_d)) break;
}
printf("%d\n",a[]);
}
return ;
}
POJ2286 The Rotation Game(IDA*)的更多相关文章
- POJ - 2286 - The Rotation Game (IDA*)
IDA*算法,即迭代加深的A*算法.实际上就是迭代加深+DFS+估价函数 题目传送:The Rotation Game AC代码: #include <map> #include < ...
- POJ 2286 The Rotation Game(IDA*)
The Rotation Game Time Limit: 15000MS Memory Limit: 150000K Total Submissions: 6396 Accepted: 21 ...
- UVA-1343 The Rotation Game (IDA*)
题目大意:数字1,2,3都有八个,求出最少的旋转次数使得图形中间八个数相同.旋转规则:对于每一长行或每一长列,每次旋转就是将数据向头的位置移动一位,头上的数放置到尾部.若次数相同,则找出字典序最小旋转 ...
- 【UVa】1343 The Rotation Game(IDA*)
题目 题目 分析 lrj代码.... 还有is_final是保留字,害的我CE了好几发. 代码 #include <cstdio> #include <algorit ...
- Booksort POJ - 3460 (IDA*)
Description The Leiden University Library has millions of books. When a student wants to borrow a ce ...
- ArcGIS Desktop和Engine中对点要素图层Graduated Symbols渲染的实现 Rotation Symbol (转)
摘要 ArcGIS中,对于要素图层的渲染,支持按照要素字段的值渲染要素的大小,其中Graduated Symbols可以对大小进行分级渲染.在个人开发系统的过程中,也可以用来美化数据显 ...
- UVA - 10384 The Wall Pusher(推门游戏)(IDA*)
题意:从起点出发,可向东南西北4个方向走,如果前面没有墙则可走:如果前面只有一堵墙,则可将墙向前推一格,其余情况不可推动,且不能推动游戏区域边界上的墙.问走出迷宫的最少步数,输出任意一个移动序列. 分 ...
- 人类即将进入互联网梦境时代(IDA)
在电影<盗梦空间>中,男主角科布和妻子在梦境中生活了50年,从楼宇.商铺.到河流浅滩.一草一木.这两位造梦师用意念建造了属于自己的梦境空间.你或许并不会想到,在不久未来,这看似科幻的情节将 ...
- The Rotation Game(IDA*算法)
The Rotation Game Time Limit : 30000/15000ms (Java/Other) Memory Limit : 300000/150000K (Java/Othe ...
随机推荐
- PreferenceFragment界面透明问题
PreferenceFragment界面默认是透明的 而其布局代码框架为 <PreferenceScreen> ... </PreferenceScreen>,背景色及透明度属 ...
- angularjs hover
<ul class="pdl-15"><li ng-repeat="order in vm.selectOrders" ng-class=&q ...
- 哈哈,CSDN又支持Windows Live Writer了
从10年开始写CSDN博客,后面不支持WLW了,就不怎么写了,话说自带的编辑器确实不怎么样,不过又支持了,那就哈哈,重新开工了. 关于如何配置的,跟以前一样,详情如下所示: http://blog.c ...
- cocos2dx解析lua table数据结构 简易版.
之前一直用xml填配置, cocos2dx自带了xml解析接口, 非常方便. 但是, 接口好用也改变不了xml的结构字符太多, 书写麻烦, 乱七八糟的事实. 很早就想换lua, 无奈引擎没有现成接口, ...
- 我的项目:一个chrome插件的诞生记,名字叫jumper
选课是个问题,为了选课,便有了以下的故事. 最开始,萌生想法于2013年7月. 接着网上了解了chrome的结构知识,却发现例子是假的. 幸好有之前师兄的一个同功能插件开源,但代码写得很乱,我喜欢逻辑 ...
- ng的数据绑定
ng创建了一个自己的事件循环,当浏览器事件(常用的dom事件,xhr事件等)发生时,对DOM对应的数据进行检查,若更改了,则标记为脏值,并进入更新循环,修改对应的(可能是多个) DOM的参数.这样就实 ...
- POJ1258-Agri-Net-ACM
Description Farmer John has been elected mayor of his town! One of his campaign promises was to brin ...
- PHP通过链接获取二进制数据的方法
function urltoblob($url){ $data = @file_get_contents($url); //如果file得不到数据,则给空值 if(!$data){ $data = & ...
- python中去掉空行的问题
在python中处理空行时,经常会遇到一些问题.现总结经验如下: 1.遇到的空行如果只有换行符,直接使用=='\n'或者 len(line)==line.count('\n') 2.有多个空格+换行符 ...
- iOS的launch image --备用
当我们打开一款应用程序的时候,首先映入眼帘的往往并不是程序的主界面,而是经过精心设计的欢迎界面,这个界面通常会停留几秒钟,然后消失.看似很平常的一个小小的欢迎界面,其实还大有讲究. 一.为什么会出现欢 ...