QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#562650 | #8668. 回文路径 | hhiron | 0 | 40ms | 21052kb | C++14 | 1.4kb | 2024-09-13 19:47:29 | 2024-09-13 19:47:30 |
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],has2r[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]*31+s1[i]-'a';
for(int i=n+1;i>=0;i--) has1r[i]=has1r[i+1]*31+s1[i]-'a';
for(int i=1;i<=n+1;i++) has2l[i]=has2l[i-1]*31+s2[i]-'a';
for(int i=n+1;i>=0;i--) has2r[i]=has2r[i+1]*31+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;
l=-1,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+l+1);
// 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]*31;
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-2;
return 0;//fghdfg
}
詳細信息
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 0
Wrong Answer
time: 0ms
memory: 8012kb
input:
1000 mfmlkrasfiudkzrjzyrlbpitvzfrlmjdzsurtdcmnqpsyfgobbstvplqylvciloomaljyssxtrrccywyirfvlcnchwkfwbdaoxzpfpvlruptganojnfxmnlqetptmlmoyluxvaipghtlaszoozscdmjomobyzboqqmvqjpbfjsoczhkwrlcauzjceqikbaeuiqahnldpqmohfjfzgkbfdbqnoxispkejvpncwsyelebqumapgbfdrjvuaxaphnkciwzkruijmanwslkwosgyfhwbnsthhtxrhrzlgtt...
output:
8
result:
wrong answer 1st lines differ - expected: '6', found: '8'
Subtask #2:
score: 0
Wrong Answer
Test #11:
score: 20
Accepted
time: 40ms
memory: 21052kb
input:
100000 ibhqhodaqcwqggmckoemulhkgbfidceskhefhsonccepfodalabaqgobpgcnaervbccadkbtsdigsoqochklocgbjjqcdhwrlacamprsoilyhiwkkjalicedhbxajrkhjgivjhnfdibkdwtexnnriegejazmohlfijbeigfmpngncokxhifjfuwuogccdfglfbxobnarmgfhgpnjjewicgfhcmfbbnjbbjjtbprnagpchcihcihfhcikeaecefdgeegtzlfdolhfieahiehdfcaflmndmcojceblf...
output:
9
result:
ok single line: '9'
Test #12:
score: 20
Accepted
time: 38ms
memory: 20080kb
input:
100000 fruiifpdggdnsbgamakpjipicaidfdjpffioqcwioaafbpdagmbbakqpekjabcljockpvcifilcjakhcboolgjbnmmrbeawcjopbccjgncdaucighprheiaqofriccfdbydbhijeelbthsmqbhcddlfemqkvdbflkdrifckarqwlaafifmqibssfukblchalkzdefnccaiabrhcrmisdeiqddccrqhiiwcqqakbfhebkiecahgdlibhgmegkfbuibcarcbajpdeboigeoctdljmqeckdfqahiecla...
output:
9
result:
ok single line: '9'
Test #13:
score: 0
Wrong Answer
time: 35ms
memory: 16632kb
input:
99999 biwnbsgdlxognjnepijlgbfbbahicjfqhdhcielcovdflacbrgcfapifaylqfmvipcccoofthuutfheboncacenchdgfljpidjbasdsikduidkbdqckmlnbfaidlincqkccbbpmnqnpbjoclgeduitraqmdfgdqinhddgberlbnlgggoafgqllbifekoccpgemcgdiiackkcfjgddhieabhzdjfwegcbuncdadebglitgwcbpmclfijmqtbbnbbrcehhanjgbddiaoimmkehtloreemecckjejifck...
output:
9
result:
wrong answer 1st lines differ - expected: '11', found: '9'
Subtask #3:
score: 0
Skipped
Dependency #1:
0%