首页 技术 正文
技术 2022年11月8日
0 收藏 780 点赞 1,858 浏览 3651 个字

4453: cys就是要拿英魂!

Time Limit: 3 Sec  Memory Limit: 128 MB
Submit: 90  Solved: 46
[Submit][Status][Discuss]

Description

pps又开始dota视频直播了!一群每天被pps虐的蒟蒻决定学习pps的操作技术,他们把pps在这局放的技能记录了下来,每个技能用一个字符表示。经过研究,蒟蒻们发现字典序更大的连招威力更大。于是所有蒟蒻都想学习pps最强的连招。但是他们太弱了,不能学会整个视频里的连招,只能学会陈老师一段区间间内的连招,可是这个他们求不出,于是只好向你求助。为了蒟蒻们不再被pps虐(怎么可能),请你帮帮他们。简化题意:给你一个字符串,每次询问你一段区间的字典序最大的子串。

Input

第一行是一个字符串S,表示pps放的技能第二行一个正整数Q,表示询问个数接下来Q行,每行两个正整数[l,r],表示询问区间[l,r]中的字典序最大的子串。

Output

Q行,每行一个正整数,表示该区间内字典序最大的子串的起始位置。

Sample Input

Lets_go_mod_p!
5
2 2
3 3
2 5
1 10
2 9

Sample Output

2
3
3
3
3
数据范围:
1<=|S|<=100000
1<=Q<=100000
1<=l<=r<=|S|


讲课的时候方法大体明白,但是不明白怎么用可删除并查集实现于是又找题解和代码研究了一遍,学到好多神奇的东西 CA爷好强:http://blog.csdn.net/creationaugust/article/details/51037027题解:https://post.icpc-camp.org/d/142-neerc-2012-moscow-subregional-d-darkwing-duck/3BZOJ 4453: cys就是要拿英魂![后缀数组 ST表 单调栈类似物] 感觉上面有的地方说的让人有点不太好…..这种求最大一个方法就是按询问右端点维护单调栈然后在单调栈里二分吧(二分找>=l的第一个,因为是递减的栈)观察一段区间内,对于两个i<j,sufi<sufj,但是r<j+lcp(i,j)时这段区间i是大于j的,所以i应该保留当r到了j+lcp(i,j)时,这个i就要删去了支持任意位置删除的单调栈?linkct讲的可以用可删除并查集然而并不明白这里的方法是用set维护“当前应该在栈里的元素”,因为set是支持删除和二分查找的到了一个r,从栈顶开始找,如果栈顶永远比sufr大就退出,否则找到st[top]开始比r小的位置,标记一下到这个位置时就删除st[top],并且如果r被删除了st[top]也要删除哦!(因为r小st[top]一定小,因为小的是lcp部分)所以用两个邻接链表h和hd表示(这一步好神啊),到位置r用dfs删除r位置需要删除的 对于询问按右端点排序,和上道题一样可以使用链表的方法

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <set>
using namespace std;
const int N=1e5+;
inline int read(){
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-; c=getchar();}
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return x*f;
}
int n,Q,l,r;
char s[N];
struct edge{
int v,ne;
}e[N],ed[N];
int cnt,h[N],hd[N],cntd;
inline void ins(int u,int v){
cnt++;
e[cnt].v=v;e[cnt].ne=h[u];h[u]=cnt;
}
inline void insd(int u,int v){
int &cnt=cntd,*h=hd;edge *e=ed;
cnt++;
e[cnt].v=v;e[cnt].ne=h[u];h[u]=cnt;
}
struct ques{
int l,id,ne;
}q[N];
int cntq,hq[N];
inline void insq(int r,int l,int id){
int &cnt=cntq,*h=hq;
cnt++;
q[cnt].l=l;q[cnt].ne=h[r];h[r]=cnt;
q[cnt].id=id;
}int sa[N],rnk[N],t1[N],t2[N],height[N],c[N];
bool cmp(int *r,int a,int b,int j){
return a+j<=n&&b+j<=n&&r[a]==r[b]&&r[a+j]==r[b+j];
}
void getSA(int m){
int *r=t1,*k=t2;
for(int i=;i<=n;i++) c[r[i]=s[i]]++;
for(int i=;i<=m;i++) c[i]+=c[i-];
for(int i=n;i>=;i--) sa[c[r[i]]--]=i;
for(int j=;j<=n;j<<=){
int p=;
for(int i=n-j+;i<=n;i++) k[++p]=i;
for(int i=;i<=n;i++) if(sa[i]>j) k[++p]=sa[i]-j; for(int i=;i<=m;i++) c[i]=;
for(int i=;i<=n;i++) c[r[k[i]]]++;
for(int i=;i<=m;i++) c[i]+=c[i-];
for(int i=n;i>=;i--) sa[c[r[k[i]]]--]=k[i]; swap(r,k);p=;r[sa[]]=++p;
for(int i=;i<=n;i++) r[sa[i]]=cmp(k,sa[i],sa[i-],j)?p:++p;
if(p>=n) break;m=p;
}
}
void getHeight(){
for(int i=;i<=n;i++) rnk[sa[i]]=i;
int k=;
for(int i=;i<=n;i++){
if(k) k--;
if(rnk[i]==) continue;
int j=sa[rnk[i]-];
while(i+k<=n&&j+k<=n&&s[i+k]==s[j+k]) k++;
height[rnk[i]]=k;
}
}
int Log[N],Pow[],mn[N][];
void iniST(){
Pow[]=;for(int i=;i<;i++)Pow[i]=Pow[i-]<<;
Log[]=-;for(int i=;i<=n;i++)Log[i]=Log[i/]+;
}
void getST(int mn[N][],int a[]){
for(int i=;i<=n;i++) mn[i][]=a[i];
for(int j=;j<=Log[n];j++)
for(int i=;i+Pow[j]-<=n;i++)
mn[i][j]=min(mn[i][j-],mn[i+Pow[j-]][j-]);
}
int lcp(int x,int y){
x=rnk[x];y=rnk[y];
if(x>y) swap(x,y);x++;
int t=Log[y-x+];
return min(mn[x][t],mn[y-Pow[t]+][t]);
}int vis[N];
set<int> S;
void dfs(int u){//printf("dfs %d\n",u);
vis[u]=;S.erase(u);
for(int i=hd[u];i;i=ed[i].ne)
if(!vis[ed[i].v]) dfs(ed[i].v);
}int st[N],top,ans[N];
void solve(){
for(int r=;r<=n;r++){
S.insert(r);
while(top){
int len=lcp(r,st[top]);
if(s[st[top]+len]>s[r+len]) break;
ins(r+len,st[top]);insd(r,st[top]);top--;
}
st[++top]=r;
for(int i=h[r];i;i=e[i].ne)
if(!vis[e[i].v]) dfs(e[i].v);
for(int i=hq[r];i;i=q[i].ne)
ans[q[i].id]=*S.lower_bound(q[i].l);
}
}
int main(){
//freopen("in.txt","r",stdin);
scanf("%s",s+);
n=strlen(s+);
getSA();getHeight();iniST();getST(mn,height);
Q=read();
for(int i=;i<=Q;i++) l=read(),r=read(),insq(r,l,i);
solve();
for(int i=;i<=Q;i++) printf("%d\n",ans[i]);
}

   

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,489
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,904
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,737
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,490
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,128
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,291