Description

对于一个给定长度为N的字符串,求它的第K小子串是什么。

Input

第一行是一个仅由小写英文字母构成的字符串S

第二行为两个整数T和K,T为0则表示不同位置的相同子串算作一个。T=1则表示不同位置的相同子串算作多个。K的意义如题所述。

Output

输出仅一行,为一个数字串,为第K小的子串。如果子串数目不足K个,则输出-1

Sample Input

aabc

0 3

Sample Output

aab

HINT

N<=5*10^5

T<2

K<=10^9

Sol

我们预处理sam上每个点按照拓扑序往后走一共几个串即可。

如果T=0,那么每个点初始权值都是1,否则按照拓扑序枚举点,然后把一个点的权值给他的pre节点累加。

之后在sam上跑26分即可。

Code

#include <bits/stdc++.h>
#define ll long long
using namespace std;
int T,n,K;char ch[500005];
struct SAM
{
int tot,last,v[1000005],s[1000005],a[1000005][26],q[1000005],mx[1000005],fa[1000005],st[1000005];
SAM(){last=++tot;}
void ins(int c)
{
int p=last,np=last=++tot;mx[np]=mx[p]+1;v[np]=1;
while(!a[p][c]&&p) a[p][c]=np,p=fa[p];
if(!p) fa[np]=1;
else
{
int q=a[p][c];if(mx[p]+1==mx[q]) fa[np]=q;
else
{
int nq=++tot;mx[nq]=mx[p]+1;memcpy(a[nq],a[q],sizeof(a[nq]));
fa[nq]=fa[q];fa[q]=fa[np]=nq;
while(a[p][c]==q) a[p][c]=nq,p=fa[p];
}
}
}
void pre()
{
for(int i=1;i<=tot;i++) st[mx[i]]++;
for(int i=1;i<=n;i++) st[i]+=st[i-1];
for(int i=tot;i;i--) q[st[mx[i]]--]=i;
for(int i=tot;i;i--) if(T==1) v[fa[q[i]]]+=v[q[i]];else v[q[i]]=1;
v[1]=0;
for(int i=tot,j;i;i--) for(s[q[i]]=v[q[i]],j=0;j<26;j++) s[q[i]]+=s[a[q[i]][j]];
}
void dfs(int x,int K)
{
if(K<=v[x]) return;K-=v[x];
for(int i=0;i<26;i++) if(a[x][i])
{
if(K<=s[a[x][i]]){putchar(i+'a');dfs(a[x][i],K);return;}
K-=s[a[x][i]];
}
}
}sam;
int main()
{
scanf("%s",ch+1);n=strlen(ch+1);scanf("%d%d",&T,&K);
for(int i=1;i<=n;i++) sam.ins(ch[i]-'a');
sam.pre();if(K>sam.s[1]) puts("-1");else sam.dfs(1,K);
}

最新文章

  1. [webpack] webpack-dev-server介绍及配置
  2. linux开启telnet
  3. Xml游标
  4. &lt;&lt;海闻电子发票接口 ESB 封装文档&gt;&gt;
  5. 有一种风格,叫做 Low Poly 3D
  6. 解决IntelliJ IDEA 13更新FindBugs 0.9.993时JRE版本过低导致启动失败问题
  7. iOS开发——UI篇OC篇&amp;UIView/UIWindow/UIScreen/CALayer
  8. JavaScript中url 传递参数(特殊字符)解决方法
  9. sql server 调优----索引未使用
  10. Cortex-A9 UART
  11. CentOS 7 服务器配置--安装nginx
  12. CountDownLatch与CyclicBarrier
  13. ThinkPHP3.2中英文切换!
  14. Ocelot 资源汇总
  15. 《前端之路》之三 数组的属性 &amp;&amp; 操作方法(下)
  16. sheet制作返回按钮
  17. 安装Lync 2013过程中遇到的第一个报错
  18. 玩转X-CTR100 l STM32F4 l 电机正交编码器
  19. Linux系统nat模式联网——VM是12 系统是cantos7
  20. Win10下安装msi程序包时报2503、2502错误问题及其解决办法

热门文章

  1. temp3
  2. 聚类 高维聚类 聚类评估标准 EM模型聚类
  3. JS||JQUERY常用语法
  4. 前端自动化之webstrom
  5. Uboot详细解析1
  6. Druid配置属性列表及含义
  7. 501. Find Mode in Binary Search Tree查找BST中的众数
  8. python 输入参数解包,模块导入,接收IO输入参数
  9. pandas dataframe 满足条件的样本提取
  10. Luogu 4721 【模板】分治 FFT