[Usaco2007 Dec]队列变换
[Usaco2007 Dec]队列变换
题目
FJ打算带他的N(1 <= N <= 30,000)头奶牛去参加一年一度的“全美农场主大奖赛”。在这场比赛中,每个参赛者都必须让他的奶牛排成一列,然后领她们从裁判席前依次走过。 今年,竞赛委员会在接受队伍报名时,采用了一种新的登记规则:他们把所有队伍中奶牛名字的首字母取出,按它们对应奶牛在队伍中的次序排成一列(比如说,如果FJ带去的奶牛依次为Bessie、Sylvia、Dora,登记人员就把这支队伍登记为BSD)。登记结束后,组委会将所有队伍的登记名称按字典序升序排列,就得到了他们的出场顺序。 FJ最近有一大堆事情,因此他不打算在这个比赛上浪费过多的时间,也就是说,他想尽可能早地出场。于是,他打算把奶牛们预先设计好的队型重新调整一下。 FJ的调整方法是这样的:每次,他在原来队列的首端或是尾端牵出一头奶牛,把她安排到新队列的尾部,然后对剩余的奶牛队列重复以上的操作,直到所有奶牛都被插到了新的队列里。这样得到的队列,就是FJ拉去登记的最终的奶牛队列。 接下来的事情就交给你了:对于给定的奶牛们的初始位置,计算出按照FJ的调整规则所可能得到的字典序最小的队列。
INPUT
第1行: 一个整数:N
第2..N+1行: 第i+1行仅有1个'A'..'Z'中的字母,表示队列中从前往后数第i 头奶牛名字的首字母
OUTPUT
第1..??行: 输出FJ所能得到的字典序最小的队列。每行(除了最后一行)输 出恰好80个'A'..'Z'中的字母,表示新队列中每头奶牛姓名的首 字母
SAMPLE
INPUT
6
A
C
D
B
C
BOUTPUT
ABCBCD
输出说明:
操作数 原队列 新队列
#1 ACDBCB
#2 CDBCB A
#3 CDBC AB
#4 CDB ABC
#5 CD ABCB
#6 D ABCBC
#7 ABCBCD
解题报告
看到这题,我们首先想到的肯定是贪心的比较两端字符,输出较小的那个
但是显然,当我们遇到如$ABA$这样的字符串时,两端相同,策略无法选择一个解出来
所以我们考虑,将字符串变成正反两个串,这样就可以相对简单的处理了
比如说样例的$ACDBCB$,我们可以加入日常分隔符,比如说$#$,然后将正反两个串相接在一起,得到$ACDBCB#BCBDCA$
然后我们可以构建出$SA$与$Rank$,我们考虑,既然我们要找相对小的字符,那么我们就可以利用$Rank$来进行操作
我们使用两个指针,一个指向正串,一个指向反串,然后进行$Rank$的比较即可
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
int T;
char txt[],ch[],s[];
int n,m;
int t1[],t2[],t3[],buc[];
int sa[],rank[];
inline void Suffix(){
int i,j,p(),*x(t1),*y(t2),*t;
for(i=;i<=m;++i)buc[i]=;
for(i=;i<=n;++i)++buc[x[i]=s[i]];
for(i=;i<=m;++i)buc[i]+=buc[i-];
for(i=n;i>=;--i)sa[buc[x[i]]--]=i;
for(j=;p<n;j<<=,m=p){
for(p=,i=n-j+;i<=n;++i)y[++p]=i;
for(i=;i<=n;++i)
if(sa[i]>j)
y[++p]=sa[i]-j;
for(i=;i<=m;++i)buc[i]=;
for(i=;i<=n;++i)t3[i]=x[y[i]];
for(i=;i<=n;++i)++buc[t3[i]];
for(i=;i<=m;++i)buc[i]+=buc[i-];
for(i=n;i>=;--i)sa[buc[t3[i]]--]=y[i];
for(t=x,x=y,y=t,x[sa[]]=,p=,i=;i<=n;++i)
x[sa[i]]=((y[sa[i]]==y[sa[i-]])&&(y[sa[i]+j]==y[sa[i-]+j]))?p:++p;
}
for(i=;i<=n;++i)rank[sa[i]]=i;
}
int main(){
scanf("%d",&T);
for(int i=;i<=T;++i){
scanf("%s",txt);
s[i]=ch[i]=txt[];
}
s[T+]='#';
for(int i=;i<=T;++i)
s[T+i+]=ch[T-i+];
n=(T<<)+;
m=;
Suffix();
int h1(),h2(T+);
while(h1-+h2-T-<T){//cout<<h1<<' '<<h2<<endl;
if(rank[h1]<rank[h2])
putchar(s[h1++]);
else
putchar(s[h2++]);
if((h1-+h2-T-)%==)
putchar('\n');
}
}
[Usaco2007 Dec]队列变换的更多相关文章
- BZOJ 1692: [Usaco2007 Dec]队列变换 [后缀数组 贪心]
1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1383 Solved: 582[Submit][St ...
- BZOJ1692: [Usaco2007 Dec]队列变换
1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 594 Solved: 246[Submit][Sta ...
- BZOJ 1692: [Usaco2007 Dec]队列变换( 贪心 )
数据 n <= 30000 , 然后 O( n² ) 的贪心也过了..... USACO 数据是有多弱啊 = = ( ps : BZOJ 1640 和此题一模一样 , 双倍经验 ) ------ ...
- 1692: [Usaco2007 Dec]队列变换(BZOJ1640强化版)
1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 682 Solved: 280[Submit][Sta ...
- [bzoj1692] [Usaco2007 Dec]队列变换 (hash||暴力)
本题同bzoj1640...双倍经验双倍幸福 虽然数据范围n=3w然而O(n²)毫无压力= = http://blog.csdn.net/xueyifan1993/article/details/77 ...
- 【BZOJ1692】[Usaco2007 Dec]队列变换 后缀数组+贪心
[BZOJ1692][Usaco2007 Dec]队列变换 Description FJ打算带他的N(1 <= N <= 30,000)头奶牛去参加一年一度的“全美农场主大奖赛”.在这场比 ...
- BZOJ_1692_[Usaco2007 Dec]队列变换_后缀数组
BZOJ_1692_[Usaco2007 Dec]队列变换_后缀数组 Description FJ打算带他的N(1 <= N <= 30,000)头奶牛去参加一年一度的“全美农场主大奖赛” ...
- bzoj1640[Usaco2007 Nov]Best Cow Line 队列变换*&&bzoj1692[Usaco2007 Dec]队列变换*
bzoj1640[Usaco2007 Nov]Best Cow Line 队列变换 bzoj1692[Usaco2007 Dec]队列变换 题意: 有一个奶牛队列.每次可以在原来队列的首端或是尾端牵出 ...
- [bzoj1692][Usaco2007 Dec]队列变换_后缀数组_贪心
队列变换 bzoj-1692 Usaco-2007 Dec 题目大意:给定一个长度为$n$的字符串.每次从头或尾取出一个字符加到另一个字符串里.要求变换后生成的字符串字典序最小,求字典序最小的字符串. ...
随机推荐
- Datatable转换为Json 的方法
/// <summary> /// Datatable转换为Json /// </summary> /// <param n ...
- PCB 规则引擎之编辑器(语法着色,错误提示,代码格式化)
对于一个规则引擎中的脚本代码编辑器是非常关键的,因为UI控件直接使用对象是规则维护者,关系到用户体验,在选用脚本编辑器的功能时除了满足代码的编辑的基本编辑要求外,功能还需要包含;语法着色,错误提示,代 ...
- SceneView 追踪选择目标
在编辑器的Scene视图中追踪选择目标,调试动作用 SceneView这个类没有说明文档比较蛋疼 在update中调用SceneViewCameraFace2Target函数,编辑器的OnInspec ...
- Akka源码分析-故障恢复
Actor故障恢复是akka中非常重要的内容,在之前的博客中虽然有介绍,但都是杂糅在其他知识点的细节中,本博客将单独介绍这一部分的故障恢复.为了简化分析的单独,本文只研究用户的actor故障恢复的步骤 ...
- nginx入门学习
1.yum解决编译nginx所需的依赖包,之后你的nginx就不会报错了 yum install gcc patch libffi-devel python-devel zlib-devel bzip ...
- ACM_lowbit
lowbit Time Limit: 2000/1000ms (Java/Others) Problem Description: long long ans = 0; for(int i = 1; ...
- 海量文本信息查Top-k
问题描述: 有1千万条短信,一条一行,有重复.在5分钟之内,找出重复出现的前10条. 方案一: 1.分组进行边扫描边建散列表.建立哈希表,使用头,尾和中间随便两个字节作为Hash Code, 插入到H ...
- js的toFixed解惑
js中的toFixed,C#中的Math.round都是按照银行家算法的定义来算的,这里只拿js作参考,各个浏览器的计算方式并不一样,先看一张图,对比参数很容易就发现了其中的不同之处: 前三个Chro ...
- SublimeText学习(二)-基本操作
1.查看已安装的插件 看到已经安装的插件,看到了在上一篇中安装的Emmet 2.设置主题与字体 方法一: 方法二: 工具栏中 [Preference-浏览程序包]找到[Default文件夹]-用Sub ...
- 【反射】Java反射机制
Class 1.Class是一个类,一个描述类的类(也就是描述类本身),封装了描述方法的Method,描述字段的Filed,描述构造器的Constructor等属性 2.对象照镜子后(反射)可以 ...