loj2073 「JSOI2016」扭动的回文串
ref
主要是要理解“撑到“最长这个概念
(为啥我的代码这么长QAQ
#include <iostream>
#include <cstdio>
using namespace std;
typedef unsigned long long ull;
int n, pa[200005], pb[200005], ans;
ull bse1[200005], bse2[200005], hsa1[200005], hsa2[200005], hsb1[200005];
ull hsb2[200005];
const int mod1=19260817, mod2=1e9+7;
char sa[200005], sb[200005];
bool iseq(int a, int b, int c, int d){
if(a>b) return true;
ull sa1=0, sb1=0;
if(a)
sa1 = hsa1[a-1] * bse1[b-a+1] % mod1;
sa1 = (hsa1[b] - sa1 + mod1) % mod1;
if(d!=n-1)
sb1 = hsb1[d+1] * bse1[d-c+1] % mod1;
sb1 = (hsb1[c] - sb1 + mod1) % mod1;
if(sa1!=sb1) return false;
sa1 = sb1 = 0;
if(a)
sa1 = hsa2[a-1] * bse2[b-a+1] % mod2;
sa1 = (hsa2[b] - sa1 + mod2) % mod2;
if(d!=n-1)
sb1 = hsb2[d+1] * bse2[d-c+1] % mod2;
sb1 = (hsb2[c] - sb1 + mod2) % mod2;
if(sa1!=sb1) return false;
return true;
}
void manacher(char a[], int b[]){
int id=0, mx=0;
for(int i=1; i<n; i++){
if(i<mx) b[i] = min(b[2*id-i], mx-i);
else b[i] = 1;
while(a[i-b[i]]==a[i+b[i]]) b[i]++;
if(mx<i+b[i]) mx = i + b[i], id = i;
ans = max(ans, b[i]);
}
}
int main(){
cin>>n;
scanf("%s", sa);
scanf("%s", sb);
for(int i=n; i>=0; i--){
sa[2*i+1] = '#';
sa[2*i+2] = sa[i];
}
for(int i=n; i>=0; i--){
sb[2*i+1] = '#';
sb[2*i+2] = sb[i];
}
sa[0] = sb[0] = '$';
n = 2 * (n + 1);
bse1[0] = bse2[0] = 1;
for(int i=1; i<n; i++){
bse1[i] = bse1[i-1] * 131 % mod1;
bse2[i] = bse2[i-1] * 131 % mod2;
}
ull ff=0;
for(int i=0; i<n; i++){
ff = (ff * 131 % mod1 + sa[i]) % mod1;
hsa1[i] = ff;
}
ff = 0;
for(int i=0; i<n; i++){
ff = (ff * 131 % mod2 + sa[i]) % mod2;
hsa2[i] = ff;
}
ff = 0;
for(int i=n-1; i>=0; i--){
ff = (ff * 131 % mod1 + sb[i]) % mod1;
hsb1[i] = ff;
}
ff = 0;
for(int i=n-1; i>=0; i--){
ff = (ff * 131 % mod2 + sb[i]) % mod2;
hsb2[i] = ff;
}
manacher(sa, pa);
manacher(sb, pb);
ans--;
for(int i=1; i<n; i++){
int pos1=i-pa[i], pos2=i+pa[i]-2;
int l=0, r=min(pos1, n-pos2), mid, re;
while(l<=r){
mid = (l + r) >> 1;
if(iseq(pos1-mid+1, pos1, pos2, pos2+mid-1))
re = mid, l = mid + 1;
else r = mid - 1;
}
ans = max(ans, pa[i]+re-1);
}
for(int i=1; i<n; i++){
int pos1=i-pb[i]+2, pos2=i+pb[i];
int l=0, r=min(pos1, n-pos2), mid, re;
while(l<=r){
mid = (l + r) >> 1;
if(iseq(pos1-mid+1, pos1, pos2, pos2+mid-1))
re = mid, l = mid + 1;
else r = mid - 1;
}
ans = max(ans, pb[i]+re-1);
}
cout<<ans<<endl;
return 0;
}
loj2073 「JSOI2016」扭动的回文串的更多相关文章
- 【LOJ】#2073. 「JSOI2016」扭动的回文串
题解 就是一个回文串拼上左右两端 类似二分找lcp这么做 可以直接用哈希找回文串 注意要找A串前半部分,B串找后半部分 代码 #include <bits/stdc++.h> #defin ...
- 【BZOJ4755】 [Jsoi2016]扭动的回文串
BZOJ4755 [Jsoi2016]扭动的回文串 Solution 考虑对于他给出的 A中的一个回文串: B中的一个回文串: 或者某一个回文的扭动字符串S(i,j,k) 这样子几个限制,我们1,2就 ...
- [BZOJ]4755: [Jsoi2016]扭动的回文串
Time Limit: 10 Sec Memory Limit: 512 MB Description JYY有两个长度均为N的字符串A和B. 一个"扭动字符串S(i,j,k)由A中的第i ...
- [bzoj4755][Jsoi2016]扭动的回文串
来自FallDream的博客,未经允许,请勿转载,谢谢. JYY有两个长度均为N的字符串A和B. 一个“扭动字符串S(i,j,k)由A中的第i个字符到第j个字符组成的子串与B中的第j个字符到第k个字符 ...
- 【题解】Luogu P4324 [JSOI2016]扭动的回文串
原题传送门 这题实际挺水的 先对两个字符串分别跑马拉车 就能求出1.2类扭动回文串最大的长度 考虑第三类的扭动回文串\(S(i,j,k)\),一定可以表示为\(A(i,l)+A(l+1,j)+B(j, ...
- [JSOI2016]扭动的回文串
题目 非常板子了 看到求什么最长的回文,我们就想到枚举回文中心的方法 首先对于这个回文串只包含在一个串内的情况,我们随便一搞就可以了,大概\(Manacher\)一下就没有了 对于那种扭动的回文串,我 ...
- BZOJ4755: [JSOI2016]扭动的回文串——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=4755 JYY有两个长度均为N的字符串A和B. 一个“扭动字符串S(i,j,k)由A中的第i个字符到 ...
- 【BZOJ4755】扭动的回文串(Manacher,哈希)
[BZOJ4755]扭动的回文串(Manacher,哈希) 题面 BZOJ 题解 不要真的以为看见了回文串就是\(PAM,Manacher\)一类就可以过. 这题显然不行啊. 我们主要考虑如何解决跨串 ...
- 非确定性有穷状态决策自动机练习题Vol.1 A.扭动的回文串
非确定性有穷状态决策自动机练习题Vol.1 A.扭动的回文串 题目描述 \(JYY\)有两个长度均为\(N\)的字符串\(A\)和\(B\). 一个"扭动字符串\(S(i,j,k)\)由\( ...
随机推荐
- webapp一些样式记录
图片外面的div设置宽高自适应width: 100vw; max-width: 640px; display: block; height: 43.75vw; max-height: 280px; f ...
- Android 环信 调用相机崩掉 mikdir()
protected void selectPicFromCamera() { if (!EaseCommonUtils.isSdcardExist()) { Toast.makeText(getAct ...
- Google地址
Google的访问一直很不稳定,经常被墙,无意间发现以下一些地址,特此记录. https://g.ttlsa.com/ https://wen.lu/ http://sinaapp.co https: ...
- 截取网卡IP地址
方法一: ifconfig eth1|awk 'NR==2 {print $2}' 方法二"" ifconfig eth1|grep -Po "(?<=inet ) ...
- JAVA时间加工类
/** * 当天凌晨 */ public static Calendar startOfDay(Calendar c) { if (c == null) { return c; } c.set(Cal ...
- 基于PowerShell的Lync Server管理 使用C#
这里所说的Lync Server管理,指通过C#管理Lync账号的启用,禁用,开启账户的语音功能. Lync服务器安装后,会自动创建一个用于远程管理的应用程序,通过IIS查看,其应用程序名为: Lyn ...
- POJ - 3111 K Best(二分)
包含一些ai和bi的集用S来表示,x = max(sigma(ai)/sigma(bi),i 属于S) ,k 表示S的大小,k= |S|. x和k之间具有单调性.k0 < k1 → x0 ≥ x ...
- 前端三大框架 Vue.js、AngularJS、React 的区别
Vue.js Vue.js 是一种构建数据驱动的Web界面的渐进式框架,Vue.js 采用自底向上增量开发的设计. Vue.js 轻量高效,数据双向绑定(响应式数据绑定), 它会自动响应数据的变化情况 ...
- 启动Jmeter时遇到的几种错误
1.权限不够 解决办法:用管理员权限运行 2.sdk版本太低 解决办法:1)查看当前sdk版本:java -version 2)安装sdk1.7或以上版本(jmeter3.0版本要用sdk1.7及以上 ...
- shell脚本,awk结合正则来打印文件里面的内容。
文件内容如下:key1abc d key2 1.想得到如下结果: abc d 2.想得到如下结果: key1key2