[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
B

OUTPUT

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]队列变换的更多相关文章

  1. BZOJ 1692: [Usaco2007 Dec]队列变换 [后缀数组 贪心]

    1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1383  Solved: 582[Submit][St ...

  2. BZOJ1692: [Usaco2007 Dec]队列变换

    1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 594  Solved: 246[Submit][Sta ...

  3. BZOJ 1692: [Usaco2007 Dec]队列变换( 贪心 )

    数据 n <= 30000 , 然后 O( n² ) 的贪心也过了..... USACO 数据是有多弱啊 = = ( ps : BZOJ 1640 和此题一模一样 , 双倍经验 ) ------ ...

  4. 1692: [Usaco2007 Dec]队列变换(BZOJ1640强化版)

    1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 682  Solved: 280[Submit][Sta ...

  5. [bzoj1692] [Usaco2007 Dec]队列变换 (hash||暴力)

    本题同bzoj1640...双倍经验双倍幸福 虽然数据范围n=3w然而O(n²)毫无压力= = http://blog.csdn.net/xueyifan1993/article/details/77 ...

  6. 【BZOJ1692】[Usaco2007 Dec]队列变换 后缀数组+贪心

    [BZOJ1692][Usaco2007 Dec]队列变换 Description FJ打算带他的N(1 <= N <= 30,000)头奶牛去参加一年一度的“全美农场主大奖赛”.在这场比 ...

  7. BZOJ_1692_[Usaco2007 Dec]队列变换_后缀数组

    BZOJ_1692_[Usaco2007 Dec]队列变换_后缀数组 Description FJ打算带他的N(1 <= N <= 30,000)头奶牛去参加一年一度的“全美农场主大奖赛” ...

  8. bzoj1640[Usaco2007 Nov]Best Cow Line 队列变换*&&bzoj1692[Usaco2007 Dec]队列变换*

    bzoj1640[Usaco2007 Nov]Best Cow Line 队列变换 bzoj1692[Usaco2007 Dec]队列变换 题意: 有一个奶牛队列.每次可以在原来队列的首端或是尾端牵出 ...

  9. [bzoj1692][Usaco2007 Dec]队列变换_后缀数组_贪心

    队列变换 bzoj-1692 Usaco-2007 Dec 题目大意:给定一个长度为$n$的字符串.每次从头或尾取出一个字符加到另一个字符串里.要求变换后生成的字符串字典序最小,求字典序最小的字符串. ...

随机推荐

  1. POJ2492 A Bug's Life 判断二分图

    给一个无向图,判断是否为二分图 是否有奇环.用染色法解决,也可以用并查集解决,时间复杂度是相同的,但是并查集用的内存少. 这里给出Bfs染色的代码 #include<iostream> # ...

  2. json-server的关系图谱详解(Relationships)

    json-server的关系图谱 json-server是非常好用的一款模拟REST API的工具,文档也很详细和全面.详情:json-server而其中的关系图谱是它非常强大的一个功能,可以非常方便 ...

  3. phpexecl 的基本操作

    基本使用方法分三部分:一.引入接口 // PHPExcel_IOFactory require_once dirname(__FILE__).'/Classes/PHPExcel/IOFactory. ...

  4. Java Socket编程 深入讲解?你之前真的学懂了吗

    很多人学习Socket往往会碰到这样哪样的问题,可以看看下面,加深理解.能看懂多少看懂多少. Socket是Java网络编程的基础,了解还是有好处的,这篇文章主要讲解Socket的基础编程.Socke ...

  5. $P5240 Derivation$

    神仙题. 第一场月赛的题目我到第二场月赛完了才写[由此可见我是真的菜 题目就是个大模拟加乘显然,幂的话需要将原函数.导函数的函数值用扩展欧拉定理展开 \(log\) 层.时间复杂度 \(O(T |S| ...

  6. flask 中的模板语法 jinja2及render_template的深度用法

    是时候开始写个前端了,Flask中默认的模板语言是Jinja2 现在我们来一步一步的学习一下 Jinja2 捎带手把 render_template 中留下的疑问解决一下 首先我们要在后端定义几个字符 ...

  7. 1、Web MVC简介

  8. Java系列学习(十一)-内部类

    1.内部类 (1)把类定义在另一个类的内部,该类就称为内部类 (2)内部类的访问规则 A:内部类可以直接访问外部类的成员,包括私有 B:外部类要想访问内部类的成员,必须创建对象 (3)内部类的分类 A ...

  9. 关于onActivityResult方法不执行的问题汇总

    我们不生产代码, 只是大自然的搬运工.  首先致谢: https://blog.csdn.net/sbvfhp/article/details/26858441 场景描述: 在A activity(由 ...

  10. 03-Servlet 体系结构知识梳理

    一.Servlet体系结构 Java Web应用是基于Servlet规范运行,Servlet顶层类的关联如下图: 从图可看出,Servlet规范基本围绕这几个类运行,其中,与Servlet主动关联的有 ...