UVA - 11212 Editing a Book (IDA*搜索)
题目:
给出n(1<n<10)个数字组成的序列,每次操作可以选取一段连续的区间将这个区间之中的数字放到其他任意位置。问最少经过多少次操作可将序列变为1,2,3……n。
思路:
利用IDA*来求解这个题目,首先每步操作最多可以减少3个位置错误的数字如下图(假设操作之后a、b、c都位于正确的位置)

则启发函数可以为3*cur+h > maxd*3,其中cur是枚举到当前的操作次数,h是序列中位置不对的数字个数,maxd是枚举到的答案。
可以用两重循环枚举选取的区间,然后枚举将其放到的位置,dfs知道序列符合题意。
代码:
#include <bits/stdc++.h>
#define inf 0x3f3f3f3f
#define MAX 1000000009
#define FRE() freopen("in.txt","r",stdin)
#define FRO() freopen("out.txt","w",stdout)
using namespace std;
typedef long long ll;
const int maxn = ;
int n; bool isSrot(int* buf){//判断是不是序列符合题意
for(int i=; i<n-; i++){
if(buf[i]>=buf[i+])
return false;
}
return true;
} int ErrorNum(int* buf){//输出位置不对的数字个数
int cnt = ;
for(int i=; i<n-; i++){
if(buf[i]+!=buf[i+])
cnt++;
}
return cnt;
} void numSwap(int* buf,int* original,int s,int t,int pos){//将区间放到指定的位置
int idx=;
for(; idx<pos; idx++){
buf[idx] = original[idx];
} for(int i=s; i<t; i++){//将操作的区间放入buf数组
buf[idx++] = original[i];
}
for(int i=pos; i<n; i++){//将剩余部分补全
if(i<s || i>=t){
buf[idx++] = original[i];
}
}
} bool dfs(int cur,int maxd,int* a){
if(*cur+ErrorNum(a)>*maxd) return false;
if(isSrot(a)) return true; int temp[];
for(int s=; s<n; s++){//这两重循环是用来枚举剪切的区间的长度
for(int t=s+; t<=n; t++){
for(int pos=; pos<s; pos++){//枚举区间要放入的位置,只要放到s之前就可以枚举所有的情况
//别的地方也不符合实际情况啊,做的时候写成了pos<n,结果一直T
numSwap(temp, a, s, t, pos);
if(dfs(cur+, maxd, temp))
return true;
}
}
}
return false;
} int main(){
//FRE();
int kase = ,a[];
while(scanf("%d",&n) && n){
for(int i=; i<n; i++){
scanf("%d",&a[i]);
} for(int i=; i<=n; i++){
if(dfs(,i,a)){
printf("Case %d: %d\n",++kase,i);
break;
}
}
}
return ;
}
UVA - 11212 Editing a Book (IDA*搜索)的更多相关文章
- UVa 11212 Editing a Book (IDA* && 状态空间搜索)
		
题意:你有一篇n(2≤n≤9)个自然段组成的文章,希望将它们排列成1,2,…,n.可以用Ctrl+X(剪切)和Ctrl+V(粘贴)快捷键来完成任务.每次可以剪切一段连续的自然段,粘贴时按照顺序粘贴.注 ...
 - UVA - 11212 Editing a Book (IDA*)
		
给你一个长度为n(n<=9)的序列,每次可以将一段连续的子序列剪切到其他地方,问最少多少次操作能将序列变成升序. 本题最大的坑点在于让人很容易想到许多感觉挺正确但实际却不正确的策略来避开一些看似 ...
 - UVA 11212 Editing a Book [迭代加深搜索IDA*]
		
11212 Editing a Book You have n equal-length paragraphs numbered 1 to n. Now you want to arrange the ...
 - UVA - 11212 Editing a Book(IDA*算法+状态空间搜索)
		
题意:通过剪切粘贴操作,将n个自然段组成的文章,排列成1,2,……,n.剪贴板只有一个,问需要完成多少次剪切粘贴操作可以使文章自然段有序排列. 分析: 1.IDA*搜索:maxn是dfs的层数上限,若 ...
 - uva 11212 - Editing a Book(迭代加深搜索 IDA*) 迭代加深搜索
		
迭代加深搜索 自己看的时候第一遍更本就看不懂..是非常水,但智商捉急也是没有办法的事情. 好在有几个同学已经是做过了这道题而且对迭代加深搜索的思路有了一定的了解,所以在某些不理解的地方询问了一下他们的 ...
 - UVA 11212 Editing a Book
		
题意: 有一篇由n个自然段组成的文章.希望将他们排成递增序列.只能剪贴和粘贴交替进行,剪贴时可以剪贴一段连续的自然段. 分析: 用IDA*算法求解.当3*d+h>maxd时剪枝. 代码: #in ...
 - Editing a Book UVA - 11212 IDA*
		
You have n equal-length paragraphs numbered 1 to n . Now you want to arrange them in the order of 1 ...
 - [BZOJ 1085] [SCOI2005] 骑士精神 [ IDA* 搜索 ]
		
题目链接 : BZOJ 1085 题目分析 : 本题中可能的状态会有 (2^24) * 25 种状态,需要使用优秀的搜索方式和一些优化技巧. 我使用的是 IDA* 搜索,从小到大枚举步数,每次 DFS ...
 - UVA - 10118Free Candies(记忆化搜索)
		
题目:UVA - 10118Free Candies(记忆化搜索) 题目大意:给你四堆糖果,每一个糖果都有颜色.每次你都仅仅能拿随意一堆最上面的糖果,放到自己的篮子里.假设有两个糖果颜色同样的话,就行 ...
 
随机推荐
- location.replace
			
[root@bigdata-server-01 ~]# curl www.baidu.com<!DOCTYPE html><!--STATUS OK--><html> ...
 - 【Codeforces】665E Beautiful Subarrays
			
E. Beautiful Subarrays time limit per test: 3 seconds memory limit per test: 512 megabytes input: st ...
 - JeePlus:项目部署
			
ylbtech-JeePlus:项目部署 1.返回顶部 1. 项目部署 1 开发工具:idea/eclipse/myeclipse+ mysql/oracle+tomcat6/7/8. 下面以ecli ...
 - bzoj1791
			
1791: [Ioi2008]Island 岛屿 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 1680 Solved: 369[Submit][S ...
 - Python Matplotlib模块--pylab
			
#-*- coding: utf-8 -*- ''' subplot(m,n,p):其中,m表示是图排成m行,n表示图排成n列,也就是整个figure中有n个图是排成一行的,一共m行,如果m=2就是表 ...
 - bzoj 1629: [Usaco2007 Demo]Cow Acrobats【贪心+排序】
			
仿佛学到了贪心的新姿势-- 考虑相邻两头牛,交换它们对其他牛不产生影响,所以如果交换这两头牛能使这两头牛之间的最大值变小,则交换 #include<iostream> #include&l ...
 - Android框架式编程之EasyPermissions
			
EasyPermission库是一个谷歌官方提供的简化基本的系统权限逻辑的库,可用于在Android M或者更高版本上. 官方项目地址:https://github.com/googlesamples ...
 - 小记  react 数据存储位置
			
react 中状态的六个存储位置 state 我想大家都知道这个地方,而且在使用 setState 时会触发组件的更新 class prop 将值存在 class 的对象中,如: class App ...
 - curl 做爬虫 用服务器代理ip
			
有时候会ip会封锁,所以会用一些模拟代理ip进行抓取测试 从网上找了一下代码 function curl_string ($url,$user_agent,$proxy){ $ch = ...
 - 'latin-1' codec can't encode characters in position解决字符问题
			
当遇到这样的报错时,原因是: pymysql库在处理mysql语句时,默认的编码方式是'latin-1',这种编码方式能识别的字符是有限的 解决办法:找到\site-packages\pymysql\ ...