FZOJβ #31.字符串
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.字符串的更多相关文章
- 31:字符串p型编码
31:字符串p型编码 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB 描述 给定一个完全由数字字符('0','1','2',…,'9')构成的字符串str,请写出s ...
- AC日记——字符串P型编码 openjudge 1.7 31
31:字符串p型编码 总时间限制: 1000ms 内存限制: 65536kB 描述 给定一个完全由数字字符('0','1','2',…,'9')构成的字符串str,请写出str的p型编码串.例如: ...
- NOI 1.7编程基础之字符串(35题)
01:统计数字字符个数 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB 描述 输入一行字符,统计出其中数字字符的个数. 输入 一行字符串,总长度不超过255. 输出 ...
- Python之字符串的特性及常用方法
字符串的特性 索引: (索引是从0开始) s='hello'print(s[0])print(s[4])print(s[-1]) #拿出最后一个字符 hoo12345678截取s[start:stop ...
- Python基础教程之第3章 使用字符串
Python 2.7.5 (default, May 15 2013, 22:43:36) [MSC v.1500 32 bit (Intel)] on win32 Type "copyri ...
- [转]Python程序员必须知道的30条编程技巧
30 tips & tricks for Python Programming 1 直接交换两个数字位置 x, y = 10, 20 print(x, y) x, y = y, x prin ...
- Swift:网络库Alamofire
一,Alamofire的说明与配置 1,什么是Alamofire (1)Alamofire 的前身是 AFNetworking.AFNetworking 是 iOS 和 OS X 上很受欢迎的第三方H ...
- QJ系列笔记
1.求int型数据在内存中存储时1的个数输入一个int型数据,计算出该int型数据在内存中存储时1的个数. #include<stdio.h> void main() { ; int yu ...
- 如何实现在Windows上运行Linux程序,附示例代码
微软在去年发布了Bash On Windows, 这项技术允许在Windows上运行Linux程序, 我相信已经有很多文章解释过Bash On Windows的原理, 而今天的这篇文章将会讲解如何自己 ...
随机推荐
- python创建矩阵
创建二维数组的办法 直接创建(不推荐) 列表生产式法(可以去列表生成式 - 廖雪峰的官方网站学习) 使用模块numpy创建 举个栗子: 创建一个3*3矩阵,并计算主对角线元素之和. import nu ...
- ue4 1官网编程指南总结
https://docs.unrealengine.com/latest/CHN/index.html 中编程指南 快速入门 actor生命周期 FloatingActor.h #pragma onc ...
- ColorMask与Blend
Shader "N/T" { Properties { _Color ("Texture to blend", Color) = (1,1,1,1) } Sub ...
- 洛谷P3797 妖梦斩木棒
P3797 妖梦斩木棒 题目背景 妖梦是住在白玉楼的半人半灵,拥有使用剑术程度的能力. 题目描述 有一天,妖梦正在练习剑术.地面上摆放了一支非常长的木棒,妖梦把它们切成了等长的n段.现在这个木棒可以看 ...
- GYM 101933D(最短路、二分、dp)
要点 非要先来后到暗示多源最短路,求最小的最大值暗示二分 二分内部的check是关键,dp处理一下,\(dp[i]\)表示第\(i\)笔订单最早何时送达,如果在ddl之前到不了则\(return\ 0 ...
- Linux Ubuntu系统之PPP拨号经验分享
近期,工作需要,我负责开发PPP拨号模块. 说起拨号,算算时间,我已经做过2次了, 暴露年龄了,呵呵. 第一次是刚毕业做的PPOE拨号,给电信做拨号软件,在河北石家庄工作过一段时间,基于windows ...
- windows黑窗口关于java程序的常用命令
1.启动java程序 我要运行:E:\code\nhtask下的ElectricEye-0.0.1-SNAPSHOT.jar程序 #切换到程序目录cd E:\code\nhtaskE: java -j ...
- 开机报错 the connected AC adapter has a lower wattage than the recommended model which was shipped with the system。
机型:联想Thinkpad T410 报错场景:在电脑插上电源充电情况下开机,会自动进入bios setup utility提示你需要重新设置日期时间.date/time 报错提示:The conne ...
- 常用的 HTML 头部标签
曾几何时,我们已经不再手写 HTML 标签.Emmet.Markdown 等工具让我们「健步如飞」,但是我们真的了解这些标签了吗? 基本标签 使用 HTML5 doctype,不区分大小写. < ...
- [拾零]C/C++_代码复用的实现_静态链接库_动态链接库_使用.def导出
1 静态链接库 1.1 创建静态链接库: 1.在VC6中创建项目:Win32 Static Library 2.在项目中创建两个文件:xxx.h 和 xxx.cpp 3.编译 1.2 使用静态链接库 ...