P5287-[HNOI2019]JOJO【KMP】

正题

题目链接:https://www.luogu.com.cn/problem/P5287


题目大意

开始一个空串,nnn个操作

  1. 在末尾加入xxxccc字符(保证和ccc和前面的字符不同)
  2. 返回到第xxx次操作之后

每次操作完成后求所有前缀的最长的borderborderborder长度和

1≤n≤1051\leq n\leq 10^51n105


解题思路

二操作好像是一个离线树能搞出来的先只考虑一操作,因为是相当于求kmpkmpkmp之后的nextnextnext和,所以可以考虑一下用kmpkmpkmp

每个插入操作我们可以看做插入了一个二元组(c,x)(c,x)(c,x)nxtinxt_inxti表示按照二元组完全匹配来KMP的nextnextnext数组。

然后求答案的时候设现在这个二元组(c,x)(c,x)(c,x),已经匹配到nownownowccc,然后往前跳nxtnxtnxt的时候如果下一个二元组的字符是ccc且数量x>nowx>nowx>now那么我们就往后计算答案然后让now=xnow=xnow=x

然后最后剩下的一些如果能和第一个匹配就全都匹配。

然后这样跑是能过的,但是加了二操作之后就会TTT,因为KMP是均摊复杂度的,会被hackhackhack

所以考虑一下怎么优化,我们知道broderbroderbroder可以被划分成logloglog个等差数列,而且一定是按照长度来排列的,如果我们发现我们跳进了一个无法匹配的等差数列中我们就直接跳到这个等差数列结束的位置因为这个等差数列中已经不能匹配了。

这样复杂度就到了O(nlog⁡n)O(n\log n)O(nlogn)


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
#define ll long long
using namespace std;
const ll N=1e5+10,P=998244353;
ll n,len,ch[N][2],s[N][3],ans[N],nxt[N],prt[N],p[N];
vector<ll> e[N];
ll gs(ll l,ll r)
{return (r+l)*(r-l+1)/2;}
void dfs(ll x){ll i=nxt[len++];s[len][0]=ch[x][0];s[len][1]=ch[x][1];s[len][2]=s[len-1][2]+ch[x][1];ans[len]=ans[len-1];nxt[len]=0;if(len==1){ans[len]=gs(1,ch[x][1]-1);}else{ll d=len-i;while(i&&(s[i+1][0]!=ch[x][0]||s[i+1][1]!=ch[x][1])){if(i-nxt[i]==d)i=i%d+d;d=i-nxt[i];i=nxt[i];}nxt[len]=i+(i||(ch[x][0]==s[1][0]&&ch[x][1]>=s[1][1]));ll now=0;i=nxt[len-1],d=len-1-i;while(now<ch[x][1]&&i){if(s[i+1][0]==ch[x][0]&&s[i+1][1]>now){ans[len]+=gs(s[i][2]+now+1,s[i][2]+min(ch[x][1],s[i+1][1]));now=s[i+1][1];}if(i-nxt[i]==d)i=i%d+d;d=i-nxt[i];i=nxt[i];}if(now<ch[x][1]&&s[1][0]==ch[x][0]){if(s[i+1][1]>now)ans[len]+=gs(now+1,min(ch[x][1],s[i+1][1]));now=max(now,min(ch[x][1],s[i+1][1]));ans[len]+=s[1][1]*(ch[x][1]-now);}}prt[x]=ans[len];for(ll i=0;i<e[x].size();i++)dfs(e[x][i]);len--;return;
}
signed main()
{scanf("%lld",&n);for(ll i=1;i<=n;i++){ll op;scanf("%lld ",&op);if(op==1){scanf("%lld %c",&ch[i][1],&ch[i][0]);e[p[i-1]].push_back(p[i]=i);}else{ll x;scanf("%lld",&x);p[i]=p[x];}}for(ll i=0;i<e[0].size();i++)dfs(e[0][i]);for(ll i=1;i<=n;i++)printf("%lld\n",prt[p[i]]%P);return 0;
}

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

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

相关文章

牛客题霸 [数组中只出现一次的数字] C++题解/答案

牛客题霸 [数组中只出现一次的数字] C题解/答案 题目描述 一个整型数组里除了两个数字之外&#xff0c;其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。 题解&#xff1a; 用map来记录每个数字出现几次&#xff0c;然后再循环一遍看哪个数字出现一次&#x…

Asp.NetCore依赖注入和管道方式的异常处理及日志记录

前言在业务系统&#xff0c;异常处理是所有开发人员必须面对的问题&#xff0c;在一定程度上&#xff0c;异常处理的能力反映出开发者对业务的驾驭水平&#xff1b;本章将着重介绍如何在 WebApi 程序中对异常进行捕获&#xff0c;然后利用 Nlog 组件进行记录&#xff1b;同时&a…

2021“MINIEYE杯”中国大学生算法设计超级联赛(2)I love counting(Trie树)

I love counting O{Mlog⁡aMAX(BN/B)}O\{M\log{a_{\text{MAX}}}(\text{BN/B})\}O{MlogaMAX​(BN/B)} md考场写的莫队Trie一直T #include<bits/stdc.h> using namespace std; using lllong long; using piipair<int,int>; using plipair<ll,int>; constexpr …

字符串:凯撒密码(洛谷P1914)

解析 只需将每一位ascll码加n即可 但要注意的是c的ascll码是有上限的 我一开始是这么写的&#xff1a; for(int i1;i<l;i){s[i] n;while(s[i]>z) s[i] - 26;printf("%c",s[i]);}结果&#xff1a; (真的是随便打的&#xff0c;不巧有些攻击性。。&#xff0…

P6113-[模板]一般图最大匹配【带花树】

正题 题目链接:https://www.luogu.com.cn/problem/P6113 题目大意 给出一张无向图&#xff0c;求最大匹配。 1≤n≤103,1≤m≤51041\leq n\leq 10^3,1\leq m\leq 5\times 10^41≤n≤103,1≤m≤5104 解题思路 带花树的模板&#xff0c;我也不会讲/kel 所以看下面两篇大佬的博…

牛客题霸 [跳台阶] C++题解/答案

牛客题霸 [跳台阶] C题解/答案 题目描述 一只青蛙一次可以跳上1级台阶&#xff0c;也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法&#xff08;先后次序不同算不同的结果&#xff09;。 题解&#xff1a; 递归的入门题 如果只剩一个台阶&#xff0c;只有一种跳…

.NET Core实战项目之CMS 第四章 入门篇-Git的快速入门及实战演练

写在前面上篇文章.NET Core实战项目之CMS 第三章 入门篇-源码解析配置文件及依赖注入我带着大家通过分析了一遍ASP.NET Core的源码了解了它的启动过程&#xff0c;然后又带着大家熟悉了一遍配置文件的加载方式&#xff0c;最后引出了依赖注入以及控制反转的概念&#xff01;如果…

高精度:麦森数*(洛谷P1045)

P1045 [NOIP2003 普及组] 麦森数 解析 看似只是正常的一个高精 然而 暗藏杀机 一开始随手那么一写 。。。 (即使用了快速幂)时间复杂度过于感人 后来我们发现&#xff1a; 第一问位数的计算不必真的算出来&#xff0c;只需把2的p次幂转化为10的k次幂即可&#xff08;具体请…

2021“MINIEYE杯”中国大学生算法设计超级联赛(2)I love exam(背包)

I love exam 不知道为啥刚开始不写&#xff0c;那么简单的背包预处理dp&#xff0c;太菜了吧 fi,jf_{i,j}fi,j​对于第i门课来说花费j天得到的最大分数 gi,j,pg_{i,j,p}gi,j,p​考虑前i门课&#xff0c;花费j天复习得到的最大分数 #include<bits/stdc.h> using namespa…

P2012-拯救世界2【EGF】

正题 题目链接:https://www.luogu.com.cn/problem/P2012 题目大意 121212种东西排列成长度为nnn的序列&#xff0c;要求前四种出现奇数次&#xff0c;后四种出现偶数次&#xff0c;求方案。TTT组数据&#xff0c;对10910^9109取模。 1≤n<263,1≤T≤21051\leq n< 2^{63}…

彼之蜜糖,吾之砒霜——聊聊软件开发中的最佳实践

“描述一个事物&#xff0c;唯有一个名词定义它的概念&#xff0c;唯有一个动词揭露它的行为&#xff0c;唯有一个形容词表现它的特征。要做的&#xff0c;就是用心去寻找那个名词、那个动词、那个形容词……”—— 福楼拜 (Gustave Flaubert)我想讲个故事。很久很久以前&#…

贪心: Array Splitting(数列分段)(洛谷CF1175D)

解析 这题可以转化一下&#xff1a; &#xff08;《神笔马良》。。。。&#xff09; 计算这些长方形对应下标的总加和 我们可以一层一层往上垒,假设第i层起始点为xi&#xff0c;总和为sumi&#xff0c;再设从1到i的前缀和为si 显然第一层x11&#xff0c;sum1sn 对于第二层x2&…

牛客题霸 [合并有序链表] C++题解/答案

牛客题霸 [合并有序链表] C题解/答案 题目描述 将两个有序的链表合并为一个新链表&#xff0c;要求新的链表是通过拼接两个链表的节点来生成的。 题解&#xff1a; 首先判断l1和l2是否为空 然后依次比较l1和l2的值&#xff0c;然后存到新的链表里&#xff0c;当有一方全部结…

2021牛客暑期多校训练营2 G.League of Legends(转化+单调队列)

G.League of Legends Zechariah_2001题解 对于可以包含其他区间的大区间&#xff0c;要使得答案最优无非就是两种分组方式&#xff1a;单独一组或者与被包含的区间一组。单独一组那么贡献就是区间长度&#xff1b;如果说与被包含的区间一组&#xff0c;对答案贡献为0&#xff…

P5056-[模板]插头dp

正题 题目链接:https://www.luogu.com.cn/problem/P5056 题目大意 n∗mn*mn∗m的网格&#xff0c;求有多少条回路可以铺满整个棋盘。 解题思路 插头dpdpdp的&#xff0c;写法是按照题解上的写法。 状态用的是括号匹配&#xff0c;然后用了哈希邻接表&#xff08;挂表&#x…

牛客题霸 [用两个栈实现队列] C++题解/答案

题目描述 用两个栈来实现一个队列&#xff0c;完成队列的Push和Pop操作。 队列中的元素为int类型。 题解&#xff1a; 我们都知道栈的性质是先进后出&#xff0c;队列是先进先出 我们用两个栈来模拟出队列 可以先用一个栈来存数&#xff0c;当要输出时&#xff0c;最上面的是…

Docker最全教程——从理论到实战(一)

容器是应用走向云端之后必然的发展趋势&#xff0c;因此笔者非常乐于和大家分享我们这段时间对容器的理解、心得和实践。本篇教程持续编写了2个星期左右&#xff0c;只是为了大家更好地了解、理解和消化这个技术&#xff0c;能够搭上这波车。你可以关注我们的公众号“magiccode…

二分:路标设置(洛谷)

传送门. 解析 只需二分枚举空旷指数即可 对于单次判断的check函数&#xff0c;可以相当于n个路标把路面分成n1个间隔&#xff0c;而对于每个间隔[l,r]和空旷指数x&#xff08;边界已有路标&#xff09;&#xff0c;所需路标应为&#xff1a; (r-l-1)/x&#xff08;比如[2,5…

2020 ICPC亚洲区域赛(沈阳)F-Kobolds and Catacombs(思维+模拟)

F-Kobolds and Catacombs 考虑每一段&#xff0c;先找到最小的&#xff0c;然后把编号小于它的都化为一组&#xff0c;此时有一个最大值需要把小于最大值的在划分进来&#xff0c;然后又有编号小于它的&#xff0c;于是再把编号小于它的划分为一组&#xff0c;while1 循环一下…

P3190-[HNOI2007]神奇游乐园【插头dp】

正题 题目链接:https://www.luogu.com.cn/problem/P3190 题目大意 n∗mn*mn∗m的网格上有权值&#xff0c;求一条权值和最大的不交回路。 1≤n≤100,1≤m≤61\leq n\leq 100,1\leq m\leq 61≤n≤100,1≤m≤6 解题思路 经典的棋盘形插头dpdpdp&#xff0c;和模板不同的地方是求…