QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#562726 | #8668. 回文路径 | hhiron | 0 | 48ms | 17588kb | C++14 | 1.5kb | 2024-09-13 20:18:41 | 2024-09-13 20:18:42 |
Judging History
answer
#include<bits/stdc++.h>
#define INF 0x7fffffff
typedef unsigned long long ull;
typedef long long ll;
using namespace std;
const int N=5e5+5;
int n;
ull has1l[N],has2l[N],has1r[N],po[N];
string a,b,s1,s2;
inline ull gethash(int x,int y,ull *has){
return (has[y]-has[x]*po[abs(x-y)]);
}int ans=0;
void solve(){
has1l[0]=s1[0]-'a',has2l[0]=s2[0]-'a';
// cout<<s1<<endl<<s2<<endl;
for(int i=1;i<=n+1;i++) has1l[i]=has1l[i-1]*131+s1[i]-'a';
for(int i=n+1;i>=0;i--) has1r[i]=has1r[i+1]*131+s1[i]-'a';
for(int i=1;i<=n+1;i++) has2l[i]=has2l[i-1]*131+s2[i]-'a';
for(int i=1;i<=n;i++){
int l=0,r=min(n,n-i)+1;
while(r-l>1){
int mid=(l+r)>>1;
if(gethash(i-mid,i+mid,has1l)==gethash(i+mid,i-mid,has1r)) l=mid;
else r=mid;
}int lrc=(l*2+1)/2;
int posl=i-l-1,posr=i+l-1;
int kkk=0;
while(gethash(posl,posl-kkk,has1r)==gethash(posr,posr+kkk,has2l)) kkk++;
// l=0,r=min(posl,n-posr)+1;
// while(r-l>1){
// int mid=(l+r)>>1;
// if(gethash(posl,posl-mid,has1r)==gethash(posr,posr+mid,has2l)) l=mid;
// else r=mid;
// }
ans=max(ans,lrc+kkk);
// cout<<i<<" "<<s1[i]<<" "<<l<<endl;
}
}
int main(){
cin>>n>>a>>b;
po[0]=1;
for(int i=1;i<=n*4;i++) po[i]=po[i-1]*131;
a=" "+a;
b=" "+b;
s1+='?',s2+='-';
for(int i=1;i<=n;i++){
s1+='#',s2+='#';
s1+=a[i],s2+=b[i];
}s1+='#',s2+='#',s1+='~',s2+='@';
n=n*2+1;
solve();
swap(s1,s2);
reverse(s1.begin(),s1.end()); reverse(s2.begin(),s2.end());
solve();
cout<<ans;
return 0;
}
詳細信息
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 0
Wrong Answer
time: 0ms
memory: 7632kb
input:
1000 mfmlkrasfiudkzrjzyrlbpitvzfrlmjdzsurtdcmnqpsyfgobbstvplqylvciloomaljyssxtrrccywyirfvlcnchwkfwbdaoxzpfpvlruptganojnfxmnlqetptmlmoyluxvaipghtlaszoozscdmjomobyzboqqmvqjpbfjsoczhkwrlcauzjceqikbaeuiqahnldpqmohfjfzgkbfdbqnoxispkejvpncwsyelebqumapgbfdrjvuaxaphnkciwzkruijmanwslkwosgyfhwbnsthhtxrhrzlgtt...
output:
10
result:
wrong answer 1st lines differ - expected: '6', found: '10'
Subtask #2:
score: 0
Wrong Answer
Test #11:
score: 0
Wrong Answer
time: 48ms
memory: 17588kb
input:
100000 ibhqhodaqcwqggmckoemulhkgbfidceskhefhsonccepfodalabaqgobpgcnaervbccadkbtsdigsoqochklocgbjjqcdhwrlacamprsoilyhiwkkjalicedhbxajrkhjgivjhnfdibkdwtexnnriegejazmohlfijbeigfmpngncokxhifjfuwuogccdfglfbxobnarmgfhgpnjjewicgfhcmfbbnjbbjjtbprnagpchcihcihfhcikeaecefdgeegtzlfdolhfieahiehdfcaflmndmcojceblf...
output:
11
result:
wrong answer 1st lines differ - expected: '9', found: '11'
Subtask #3:
score: 0
Skipped
Dependency #1:
0%