http://1572m36l09.iask.in:30808/problem/31

首先转化为保留尽量少的段使得字典序最大。考虑逐字符确定,
显然我们可以将相同的连续字符缩在一起。注意到字典序最大的
字符一定会在前缀中保留尽量多次,我们可以将字符相同的连续
段按照出现次数排序,并逐一确定。在确定最后一段时,我们需
要考虑剩余部分后缀对串的大小的影响。使用后缀数组处理,时
间复杂度为 O(|s| log |s|)

#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector>
using namespace std;
;
struct node
{
    int l,r;
}a[N];
vector<node> vct[];
int t,K,n,m,i,j,k,l,x,y,sa[N],rk[N],Y[N],c[N],len;
char s[N],ans[N];
bool cmp(node a,node b)
{
    return a.l<b.l;
}
bool cmq(node a,node b)
{
    if(a.r-a.l!=b.r-b.l)
        return a.r-a.l>b.r-b.l;
    return a.l<b.l;
}
void add(char c,int x)
{
    while(x--)
        ans[++len]=c;
}
int main()
{
    freopen("string.in","r",stdin);
    freopen("string.out","w",stdout);
    scanf("%d",&t);
    while(t--)
    {
        scanf();
        )//注意K==0时要特判
        {
            puts(s+);
            continue;
        }
        n=strlen(s+);
        m=;
        len=;
        ;i<=n;++i)
            rk[i]=s[i];
        ;i<=m;++i)
            c[i]=;
        ;i<=n;++i)
            c[rk[i]]++;
        ;i<=m;++i)
            c[i]+=c[i-];
        ;i<=n;++i)
            sa[c[rk[i]]--]=i;
        ;k<=n;k<<=)
        {
            ,l=;i<=n;++i)
                Y[++l]=i;
            ;i<=n;++i)
                if(sa[i]>k)
                    Y[++l]=sa[i]-k;
            ;i<=m;++i)
                c[i]=;
            ;i<=n;++i)
                c[rk[i]]++;
            ;i<=m;++i)
                c[i]+=c[i-];
            ;--i)
                sa[c[rk[Y[i]]]--]=Y[i];
            ;i<=n;++i)
                Y[i]=rk[i];
            rk[sa[]]=m=;
            ;i<=n;++i)
                rk[sa[i]]=(Y[sa[i]]==Y[sa[i-]]&&(sa[i]+k>n?:Y[sa[i]+k])==(sa[i-]+k>n?:Y[sa[i-]+k])?m:++m);
            if(rk[sa[n]]==n)//SA的一个优化
                break;
        }
        rk[n+]=;//注意细节!!
        ;i<;++i)
            vct[i].clear();
        ;i<=n;i=j)
        {
            for(j=i;j<=n&&s[i]==s[j];++j);
            vct[s[i]-});
        }
        ,j=k=;i>=;--i)
        {
            l=vct[i].size();
            if(!l)
                continue;
            sort(vct[i].begin(),vct[i].end(),cmp);
            ;x<l&&vct[i][x].l<=j;++x);
            if(x>=l)
                continue;
            )
            {
                add(i+);
                j=vct[i][x++].r;
            }
            if(l-x+k<K)
            {
                j=vct[i][l-].r;
                k+=l-x;
                for(;x<l;++x)
                    add(i+);
                continue;
            }
            sort(vct[i].begin()+x,vct[i].end(),cmq);
            ;++x)
            {
                add(i+);
                ++k;
                j=max(j,vct[i][x].r);
            }
            k=vct[i][x].r-vct[i][x].l+;
            add(i+'a',k);
            ;x<l&&vct[i][x].r-vct[i][x].l+==k;++x)
                ||rk[max(j+,vct[i][x].r+)]>rk[y])
                    y=max(j+,vct[i][x].r+);
            for(;y<=n;++y)
                add(s[y],);
            j=n;
            break;
        }
        ans[len+]=;
        puts(ans+);
    }
    ;
}

FZOJβ #31.字符串的更多相关文章

  1. 31:字符串p型编码

    31:字符串p型编码 查看 提交 统计 提问 总时间限制:  1000ms 内存限制:  65536kB 描述 给定一个完全由数字字符('0','1','2',…,'9')构成的字符串str,请写出s ...

  2. AC日记——字符串P型编码 openjudge 1.7 31

    31:字符串p型编码 总时间限制:  1000ms 内存限制:  65536kB 描述 给定一个完全由数字字符('0','1','2',…,'9')构成的字符串str,请写出str的p型编码串.例如: ...

  3. NOI 1.7编程基础之字符串(35题)

    01:统计数字字符个数 查看 提交 统计 提问 总时间限制:  1000ms 内存限制:  65536kB 描述 输入一行字符,统计出其中数字字符的个数. 输入 一行字符串,总长度不超过255. 输出 ...

  4. Python之字符串的特性及常用方法

    字符串的特性 索引: (索引是从0开始) s='hello'print(s[0])print(s[4])print(s[-1]) #拿出最后一个字符 hoo12345678截取s[start:stop ...

  5. Python基础教程之第3章 使用字符串

    Python 2.7.5 (default, May 15 2013, 22:43:36) [MSC v.1500 32 bit (Intel)] on win32 Type "copyri ...

  6. [转]Python程序员必须知道的30条编程技巧

    30 tips & tricks for Python Programming 1  直接交换两个数字位置 x, y = 10, 20 print(x, y) x, y = y, x prin ...

  7. Swift:网络库Alamofire

    一,Alamofire的说明与配置 1,什么是Alamofire (1)Alamofire 的前身是 AFNetworking.AFNetworking 是 iOS 和 OS X 上很受欢迎的第三方H ...

  8. QJ系列笔记

    1.求int型数据在内存中存储时1的个数输入一个int型数据,计算出该int型数据在内存中存储时1的个数. #include<stdio.h> void main() { ; int yu ...

  9. 如何实现在Windows上运行Linux程序,附示例代码

    微软在去年发布了Bash On Windows, 这项技术允许在Windows上运行Linux程序, 我相信已经有很多文章解释过Bash On Windows的原理, 而今天的这篇文章将会讲解如何自己 ...

随机推荐

  1. Mac下安装rJava,xlsx,ReporteRs包

    xlsx包可以用来读取excel数据,ReporteRs包可以用来直接输出word报告,这两个包都对rJava包有依赖,所以必须先安装rJava. (1)查看mac的java信息 java版本: &g ...

  2. ue4 c++ anim notify

    http://blog.csdn.net/or_7r_ccl/article/details/54564962 直接在sequence or montage中new个Event 然后在graph中接收 ...

  3. 2014-10-5 NOIP模拟赛

    祖孙询问 (tree.pas/c/cpp) [问题描述] 已知一棵n个节点的有根树.有m个询问.每个询问给出了一对节点的编号x和y,询问x与y的祖孙关系. [输入格式] 输入第一行包括一个整数n表示节 ...

  4. 洛谷P1602 Sramoc问题

    P1602 Sramoc问题 题目描述 话说员工们整理好了筷子之后,就准备将快餐送出了,但是一看订单,都傻眼了:订单上没有留电话号码,只写了一个sramoc(k,m)函数,这什么东西?什么意思?于是餐 ...

  5. ORM应用

    目录 ORM概念 ORM由来 ORM的优势 ORM的劣势 ORM总结 ORM 与 DB 的对应关系图 Model 模块 ORM操作 增删改查操作 ORM概念 对象关系映射(Object Relatio ...

  6. 聊聊 Laravel 5.5 的 「自动发现」

    ThinkSNS是什么? ThinkSNS(简称TS),一款全平台综合性社交系统,目前最新版本为ThinkSNS+.ThinkSNS V4 ThinkSNS[简]. 看了Taylor Otwell发表 ...

  7. webpack4.0介绍与使用(一)

    1:webpack的基本使用: ##在网页中会引用那些静态资源: js, css, images, 字体文件和模板文件(.vue)等 ##网页总引用静态资源多了以后会有那些问题: 网页加载速度慢,因为 ...

  8. ms sqlserver 清除数据库日志脚本

    USE [master] GO ALTER DATABASE F360DW SET RECOVERY SIMPLE WITH NO_WAIT GO ALTER DATABASE F360DW SET ...

  9. spark-2.2.0-bin-hadoop2.6和spark-1.6.1-bin-hadoop2.6发行包自带案例全面详解(java、python、r和scala)之Basic包下的JavaPageRank.java(图文详解)

    不多说,直接上干货! spark-1.6.1-bin-hadoop2.6里Basic包下的JavaPageRank.java /* * Licensed to the Apache Software ...

  10. 专题《一》 mysql优化

    从今天开始,在这里记录面试会问的问题,针对java高级开发,架构师方向. 1.数据库设计要合理.开发经验不同  设计表水平不同  影响后面操作 三范式:1------------原子约束,每列不可分割 ...