BestCoder Round #59 (div.2) B. Reorder the Books 想法题
2015-10-11 00:18
309 查看
Reorder the Books
问题描述dxy家收藏了一套书,这套书叫《SDOI故事集》,《SDOI故事集》有n(n\leq 19)n(n≤19)本,每本书有一个编号,从11号到nn号。 dxy把这些书按编号从小到大,从上往下摞成一摞。dxy对这套书极其重视,不允许任何人动这套书。 有一天Evensgn到dxy家玩,dxy因为和妹子有约会,就让Evensgn自己待在他家。Evensgn对这套书非常好奇,偷偷的看了一下,结果发现这里面竟然有当年小E和小Q的故事。Evensgn看得出神,结果把一摞书的顺序打乱了。 眼看着dxy就要回来了,Evensgn需要尽快把这摞书恢复到原先排好序的状态。由于每本书都非常重,所以Evensgn能做的操作只有把一本书从书堆中抽出来,然后把这本书放到书堆的顶部。 给你打乱的书的顺序,你能帮Evensgn算算最少需要几次上述的操作,他才能把这套书恢复顺序?假如你能算出来的话,Evensgn答应送给你一本他签名的书《SDOI故事集9:小E的故事》
输入描述
输入包含多组数据。 第一行包含一个正整数T(T\leq 30)T(T≤30)表示数据组数。 对于每组数据,第一行为一个正整数nn表示这套《SDOI故事集》中有多少本书。 接下来一行nn个用空格分开的正整数,表示Evensgn打乱后的这摞书的书号顺序(从上往下)。
输出描述
对于每组数据,输出一行一个整数,表示Evensgn最少需要几次操作才能讲书恢复顺序。
输入样例
2 4 4 1 2 3 5 1 2 3 4 5
输出样例
3 0
Hint
对于第一组数据,我们先把33号书放到最上面,接着操作22号书,最后操作11号书,(4,1,2,3)\rightarrow (3,4,1,2)\rightarrow(2,3,4,1)\rightarrow(1,2,3,4)(4,1,2,3)→(3,4,1,2)→(2,3,4,1)→(1,2,3,4),这样就有序了 对于第二组数据,这摞书本来就有序了,所以不需要任何操作 n>15n>15的数据不超过1010组 题解:从n的位置向前找,若没找到,就是当前要找的数
///1085422276 #include<bits/stdc++.h> using namespace std ; typedef long long ll; #define mem(a) memset(a,0,sizeof(a)) #define meminf(a) memset(a,127,sizeof(a)); #define TS printf("111111\n"); #define FOR(i,a,b) for( int i=a;i<=b;i++) #define FORJ(i,a,b) for(int i=a;i>=b;i--) #define READ(a,b,c) scanf("%d%d%d",&a,&b,&c) #define inf 100000 inline ll read() { ll x=0,f=1; char ch=getchar(); while(ch<'0'||ch>'9') { if(ch=='-')f=-1; ch=getchar(); } while(ch>='0'&&ch<='9') { x=x*10+ch-'0'; ch=getchar(); } return x*f; } //**************************************** #define maxn 20 int ans,a[maxn],b[maxn]; int main() { int T=read(); while(T--) { int n=read(); ans=0; FOR(i,1,n) { scanf("%d",&a[i]); b[a[i]]=i; } for(int i=n-1;i>=1;i--) { if(b[i]<b[i+1]) continue; else {ans+=i;break;} } cout<<ans<<endl; } return 0; }代码
相关文章推荐
- 数据库 | SQL
- POJ 3709 K-Anonymous Sequence (斜率优化DP)
- 可以暂停的线程池
- ajax异步加载
- [51MCU] Chapter1:概述
- [数据结构]二叉查找树 简单实现
- 【数据与算法】筛法求素数与哥德巴赫数
- [RMQ]UVa 11235 - Frequent values
- 区间DP
- <!DOCTYPE>声明
- 南洋理工ACM——阶乘的0
- 利用print2flashsetup.exe文档转swf
- Activity的启动过程
- 云桌面技术展望
- ContOS7 安装Tomcat发现service stop时候执行的是service start
- JS 对象引用和深拷贝
- 阿里云RDS实例CPU超过100%
- Gradle命令行
- [iOS]圆形进度条及计时功能
- Android中常见的设计模式