[2020.11.26NOIP模拟赛]勇者的后缀【SA,RMQ,主席树,二分】

正题

题目链接:https://www.luogu.com.cn/problem/U142356?contestId=37784


题目大意

一个字符串,询问给出(x,l,r)(x,l,r)(x,l,r)表示询问在[l,r][l,r][l,r]中作为起点找一个后缀它与xxx作为起点的后缀的LCPLCPLCP最长,且满足最长的情况下字典序最小。


解题思路

显然是要再xxx后缀数组的位置上找到一个最前的在[l,r][l,r][l,r]中的数使得LCPLCPLCP最长。

我们要先在SASASA上找到xxx[l,r][l,r][l,r]中的前驱后继,这个可以用主席树维护,然后如果是后继的LCPLCPLCP最大那么前驱直接就是答案,否则我们需要二分出一个最前的位置使得这个位置与xxxLCPLCPLCP也是最大的,之后再找这个位置的后继。

用主席树维护前驱后继的问题,我们在第iii棵树中插入rkirk_irki,然后询问(x,l,r)(x,l,r)(x,l,r)时我们查询l∼rl\sim rlr树中在[1,x−1][1,x-1][1,x1]这个范围有多少个数,若有kkk个,那么询问l∼rl\sim rlr数中第kkk个数就是前驱,后继同理。

时间复杂度O(nlog⁡n)O(n\log n)O(nlogn)(二分+RMQ,主席树的时间复杂度是分开的)


codecodecode

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std;
const int N=2e5+10;
struct ask_node{int l,r,id;
};
int n,m,rt[N],prt[N],mrk[N];
int lim,sa[N],rk[N],c[N],x[N],y[N];
int lg[N],f[N][20];
vector<ask_node> v[N];
char s[N];
void Qsort(){for(int i=1;i<=lim;i++)c[i]=0;for(int i=1;i<=n;i++)c[x[i]]++;for(int i=1;i<=lim;i++)c[i]+=c[i-1];for(int i=n;i>=1;i--)sa[c[x[y[i]]]--]=y[i],y[i]=0;return;
}
void Get_SA(){lim=26;for(int i=1;i<=n;i++)x[i]=s[i]-'a'+1,y[i]=i;Qsort();for(int w=1;w<=n;w<<=1){int p=0;for(int i=n-w+1;i<=n;i++)y[++p]=i;for(int i=1;i<=n;i++)if(sa[i]>w)y[++p]=sa[i]-w;Qsort();swap(x,y);p=x[sa[1]]=1;for(int i=2;i<=n;i++)x[sa[i]]=(y[sa[i]]==y[sa[i-1]]&&y[sa[i]+w]==y[sa[i-1]+w])?p:++p;if(p==n)break;lim=p; }return;
}
void Get_Height(){int k=0;for(int i=1;i<=n;i++)rk[sa[i]]=i;for(int i=1;i<=n;i++){if(rk[i]==1)continue;if(k)k--;int j=sa[rk[i]-1];while(i+k<=n&&j+k<=n&&s[i+k]==s[j+k])k++;f[rk[i]][0]=k;}return;
}
void Get_ST(){for(int i=2;i<=n;i++)lg[i]=lg[i/2]+1;for(int j=1;j<19;j++)for(int i=1;i+(1<<j-1)<=n;i++)f[i][j]=min(f[i][j-1],f[i+(1<<j-1)][j-1]);return;
}
int LCP(int l,int r){if(!l||!r)return -1;if(l==r) return n-sa[l]+1;if(l>r) swap(l,r);l++;int z=lg[r-l+1];return min(f[l][z],f[r+1-(1<<z)][z]);
}
struct Seg_Tree{int cnt,w[N<<5],ls[N<<5],rs[N<<5];int Change(int x,int L,int R,int pos){int now=++cnt;w[now]=w[x]+1;if(L==R)return now;int mid=(L+R)>>1;if(pos<=mid)ls[now]=Change(ls[x],L,mid,pos),rs[now]=rs[x];else ls[now]=ls[x],rs[now]=Change(rs[x],mid+1,R,pos);return now;}int Ask(int x,int y,int L,int R,int l,int r){if(!(w[y]-w[x]))return 0;if(L==l&&R==r)return w[y]-w[x];int mid=(L+R)>>1;if(r<=mid)return Ask(ls[x],ls[y],L,mid,l,r);if(l>mid)return Ask(rs[x],rs[y],mid+1,R,l,r);return Ask(ls[x],ls[y],L,mid,l,mid)+Ask(rs[x],rs[y],mid+1,R,mid+1,r);}int Query(int x,int y,int L,int R,int k){if(L==R)return L;int mid=(L+R)>>1,val=w[ls[y]]-w[ls[x]];if(k<=val)return Query(ls[x],ls[y],L,mid,k);return Query(rs[x],rs[y],mid+1,R,k-val);}
}T;
int main()
{
//	printf("%d",sizeof(T)/1024/1024);scanf("%s",s+1);n=strlen(s+1);scanf("%d",&m);for(int i=1;i<=m;i++){int x,l,r;scanf("%d%d%d",&x,&l,&r);v[x].push_back((ask_node){l,r,i});}Get_SA();Get_Height();Get_ST();for(int i=1;i<=n;i++)rt[i]=T.Change(rt[i-1],1,n,rk[i]);for(int i=1;i<=n;i++){int x=rk[i];for(int j=0;j<v[i].size();j++){int ans=0;int l=v[i][j].l,r=v[i][j].r,L,R;int sum=T.Ask(rt[l-1],rt[r],1,n,1,x-1);(sum<(T.w[rt[r]]-T.w[rt[l-1]]))?R=T.Query(rt[l-1],rt[r],1,n,sum+1):R=0;(sum)?L=T.Query(rt[l-1],rt[r],1,n,sum):L=0;ans=LCP(x,R);sum=LCP(L,x);if(ans>sum){prt[v[i][j].id]=ans;mrk[v[i][j].id]=sa[R];continue;}L=1;R=x;while(L<=R){int mid=(L+R)>>1;if(LCP(mid,x)<sum)L=mid+1;else R=mid-1;}R=T.Ask(rt[l-1],rt[r],1,n,1,L-1);prt[v[i][j].id]=sum;mrk[v[i][j].id]=sa[T.Query(rt[l-1],rt[r],1,n,R+1)];}}for(int i=1;i<=m;i++)printf("%d %d\n",prt[i],mrk[i]);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320313.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.NET Core 项目指定SDK版本

一. 版本里的坑自从 .NET Core 2.1.0版本发布以后&#xff0c;近几个月微软又进行了几次小版本的发布&#xff0c;可见 .NET Core 是一门生命力非常活跃的技术。经过一段时间的实践&#xff0c;目前做 ASP.NET Core 开发时&#xff0c;使用的 Nuget 包&#xff0c;比如 Microso…

牛客网【每日一题】4月17日题目精讲 华华给月月准备礼物

文章目录题目描述题解&#xff1a;代码&#xff1a;推荐例题&#xff1a;试题链接时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 32768K&#xff0c;其他语言65536K 64bit IO Format: %lld 题目描述 二月中旬虐狗节前夕&#xff0c;华华决定给…

[BZOJ 3173] [TJOI 2013] 最长上升子序列(splay)

根据题意很容易得到最原始的做法&#xff1a; #include<iostream> #include<cstdio> #include<cstring> #include<vector> using namespace std; const int N100005; int n,m,f[N]; int main(){scanf("%d",&n);int x;for(int i1;i<n…

P4300-[AHOI2006]上学路线【网络流,最短路】

正题 题目链接:https://www.luogu.com.cn/problem/P4300 题目大意 nnn个点mmm条边的无向图。求1∼n1\sim n1∼n的最短路和删除cic_ici​和最小的边使得最短路变长。 解题思路 显然我们需要跑一次最短路。 之后考虑如何求第二问&#xff0c;我们发现我们要割掉最短路上的边&a…

Mathematics(jzoj 1747)

Mathematics jzoj 1747 题目大意 有n堆石子&#xff0c;总和为2k2^k2k&#xff0c;现在对于两堆石子&#xff0c;你可以从a中取b的分量到b&#xff08;a要大于b&#xff09;&#xff0c;问合成一堆大小为2k2^k2k的石子要怎么做&#xff08;输出a,b&#xff09; 输入样例 2…

Bing.com在.NET Core 2.1上运行

相关知识请参考.netCore开发团队博客 https://blogs.msdn.microsoft.com/dotnet/ Bing.com是一种云服务&#xff0c;运行在遍布全球许多数据中心的数千台服务器上。Bing服务器每秒处理来自全球消费者的数千个用户查询&#xff0c;通过他们的浏览器&#xff0c;使用Microsoft认…

Jelly

链接&#xff1a; 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 131072K&#xff0c;其他语言262144K 64bit IO Format:%lld 题目描述 Nancy喜欢吃果冻&#xff01; Nancy钻进了一个n \times n \times nnnn的果冻里&#xff0c;她想从(1,1,1)一…

[bzoj 4811] 由乃的OJ(贪心 + 树链剖分)

前置技能&#xff1a;[Noi2014]起床困难综合症。 不难看出&#xff0c;这道题其实就是上一道题的加强版 在上一道题中&#xff0c;因为位运算时位与位之间互不干扰 所以从高位到低位枚举初始值二进制上的每一位为0和为1时&#xff0c;经过n次计算后这一位的结果&#xff0c;贪…

P4055-[JSOI2009]游戏【网络流,博弈】

正题 题目链接:https://www.luogu.com.cn/problem/P4055 题目大意 n∗mn*mn∗m的网格有的不能走&#xff0c;走过的不能走。开始有一个棋子先手可以决定位置&#xff0c;然后后先手轮流走&#xff0c;不能走的就输了&#xff0c;求先手的必胜开始位置。 解题思路 我们将图二分…

【贪心】逃跑(jzoj 1748)

逃跑 jzoj 1748 题目大意 你有一个能量值l&#xff0c;在接下来的n天里&#xff0c;你每天有两个选择&#xff1a; 1、增加l个食物 2、使l加一&#xff0c; 你第i天要吃ai个a_i个ai​个食物&#xff0c;如果吃不到就会死掉&#xff0c;现在问你n天后你能活下去吗&#xff0c…

c#中关于协变性和逆变性(又叫抗变)帮助理解

今天回忆了之前看的《深入理解C#》这本书中的泛型章节&#xff0c;其中对泛型的可变性的理解。泛型可变性分两种&#xff1a;协变和逆变。逆变也又称为抗变。怎么理解这两个名词的意思&#xff1a;①&#xff1a;协变即为在泛型接口类型中使用out标识的类型参数。协变的字面意思…

「木」迷雾森林

链接&#xff1a; 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 131072K&#xff0c;其他语言262144K 64bit IO Format:%lld 题目描述 赛时提示&#xff1a;保证出发点和终点都是空地 帕秋莉掌握了一种木属性魔法 这种魔法可以生成一片森林&am…

【单调队列】【DP】城市交通(jzoj 1749)

城市交通 jzoj 1749 题目大意 有n个点&#xff0c;x到y的前提是x<y,代价是(y−x)∗axby(y-x)*a_xb_y(y−x)∗ax​by​&#xff0c;问从1到n的最小代价是多少 输入样例 4 2 9 5 4 9 1 2 2输出样例 8数据范围 对于20%的数据&#xff0c;1⩽n⩽100&#xff1b;1\leqslan…

P5546-[POI2000]公共串【SAM】

正题 题面链接:https://www.luogu.com.cn/problem/P5546 题目大意 求nnn个串的最长公共子串。 解题思路 注意到最长公共子串一定是其中所有的子串&#xff0c;所以我们可以先随意对一个串构建SAMSAMSAM然后将信息存在上面即可。 然后每一个其他串都丢到那个SAMSAMSAM上跑匹…

C# 7.0中的解构功能---Deconstruct

解构元组C#7.0新增了诸多功能&#xff0c;其中有一项是新元组(ValueTuple)&#xff0c;它允许我们可以返回多个值&#xff0c;并且配合解构能更加方便的进行工作&#xff0c;如下面例子可以看到解构元组可以写出优雅的代码&#xff0c;并且可以使用类型推断&#xff0c;但在这里…

csp初赛复习(往年真题+解析)

排序算法 前缀/后缀表达式 二进制补码、反码 最短路 图片/音频/视频文件格式 前序/中序/后序遍历 以比较作为基本运算&#xff0c;在 N 个数中找最小数的最少运算次数为&#xff08; &#xff09;。 A. NNN B. N−1N-1N−1 C. N2N^2N2 D. logNlogNlogN 正确答案&#xff1a; B …

纪中B组模拟赛总结(2020.2.7)

成绩 rankrankranknamenamenamescorescorescoreT1T1T1T2T2T2T3T3T3141414lyflyflyf190190190100100100909090000 总结 T1看了一会看出是二进制&#xff0c;就敲了出来 T2想不到正解&#xff0c;就敲了一个暴力&#xff0c;竟水到了90分&#xff0c;正解是要有撤回的贪心 T3以为…

CF932F-Escape Through Leaf【树上启发式合并,CDQ分治,斜率优化dp】

正题 题面链接:https://www.luogu.com.cn/problem/CF932F 题目大意 nnn个点的一棵树&#xff0c;从xxx跳到yyy&#xff08;要求yyy在xxx的子树中&#xff09;会产生Ax∗ByA_x*B_yAx​∗By​的代价&#xff0c;求每个节点出发跳到某个叶节点的最小代价。 解题思路 考虑dpdpdp的…

ASP.NET Core 2.1中基于角色的授权

授权是来描述用户能够做什么的过程。例如&#xff0c;只允许管理员用户可以在电脑上进行软件的安装以及卸载。而非管理员用户只能使用软件而不能进行软件的安装以及卸载。它是独立的而又与验证配合使用&#xff0c;需要身份验证机制。对于应用程序来说&#xff0c;首先需要进行…

CF449B Jzzhu and Cities(Dijkstra)

设每个点到1的距离为dis[x]dis[x]dis[x],特殊边为(1,vi,wi)(1,v_i,w_i)(1,vi​,wi​) 1、wi>dis[vi]w_i>dis[v_i]wi​>dis[vi​]的特殊边可以删除 2、widis[vi]且num[vi]>1w_idis[v_i]且num[v_i]>1wi​dis[vi​]且num[vi​]>1,特殊边可以删掉 思路上的偏差&…