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的原理, 而今天的这篇文章将会讲解如何自己 ...
随机推荐
- 洛谷P3200 [HNOI2009]有趣的数列(Catalan数)
P3200 [HNOI2009]有趣的数列 题目描述 我们称一个长度为2n的数列是有趣的,当且仅当该数列满足以下三个条件: (1)它是从1到2n共2n个整数的一个排列{ai}: (2)所有的奇数项满足 ...
- CentOS6.5安装sqlite3[转]
1.下载安装包:https://www.sqlite.org/download.html 2.解压 [root@mycentos ~]# tar xzvf sqlite-snapshot-201809 ...
- 剑指Offer的学习笔记(C#篇)-- 二叉搜索树的后序遍历序列
题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 一 . 解题思想与二叉搜索树概念 (1). 二叉树 ...
- P1291-添加括号(区间dp)
题目背景 给定一个正整数序列a(1),a(2),...,a(n),(1<=n<=20) 不改变序列中每个元素在序列中的位置,把它们相加,并用括号记每次加法所得的和,称为中间和. 例如: 给 ...
- python进阶01 面向对象、类、实例、属性封装、实例方法
python进阶01 面向对象.类.实例.属性封装.实例方法 一.面向对象 1.什么是对象 #一切皆对象,可以简单地将“对象”理解为“某个东西” #“对象”之所以称之为对象,是因为它具有属于它自己的“ ...
- jQuery基础(1)
一.jQuery的介绍 1.为什么要使用jQuery? 在用js写代码时,会遇到一些问题,如下: 1)window.onload 事件有事件覆盖的问题,因此只能写一个事件: 2)代码容错性差: 3)浏 ...
- NET?.NET Framework?.NET Core?
什么是.NET?什么是.NET Framework?什么是.NET Core? https://www.cnblogs.com/1996V/p/9037603.html 什么是.NET?什么是.NET ...
- Java8中的新特性Optional
Optional 类是一个可以为null的容器对象.如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象.Optional 是个容器:它可以保存类型T的值,或者仅仅保存 ...
- 关于C#操作Excel,复制Sheet的记录
1.先用了NPOI,去做,HSSFWorkbook 里面有一个Copy方法,但这个只支持office2003. 对应的XSSFWorkbook没有些方法. 而且这个这个方法对devexpress导出的 ...
- 《springcloud 二》SrpingCloud Zuul 微服务网关搭建
网关作用 网关的作用,可以实现负载均衡.路由转发.日志.权限控制.监控等. 网关与过滤器区别 网关是拦截所有服务器请求进行控制 过滤器拦截某单个服务器请求进行控制 Nginx与Zuul的区别 Ngin ...