#include <bits/stdc++.h>
using namespace std;
#define int long long
struct Hash{
    long long a = 41 , mod = 972663749;
    long long h[3001],p[3001];
    void buld(){
        p[0] = 1;
        for(int i = 1;i<=3000;i++){
            p[i] = (p[i-1]*a)%mod;
        }
    }
    void has(string s){
        h[0] = 0;
        for(int i = 0;i<s.size();i++){
            h[i+1] = (h[i]*a+((s[i]-'a')+1))%mod;
        }
    }
    long long q(int l,int r){return(((h[r]-h[l-1]*p[r-l+1])%mod)+mod)%mod;}
}hsh1,hsh2,hsh3;
signed main(){
    ios_base::sync_with_stdio(false);cin.tie(0);
    string a,b;
    cin>>a>>b;
    hsh1.buld();
    hsh2.buld();
    hsh1.has(a);
    hsh2.has(b);
    string B = b;
    reverse(B.begin(),B.end());
    hsh3.buld();
    hsh3.has(B);
    int n = a.size();
    n = max(n,(int)b.size());n+=1;
    map<int,int> mp[n];
    int lenB = b.size();
    int st1 = -1 , st2 = -1;
    int ans = 0;
    for(int i = 0;i<a.size();i++){
        for(int j = i;j<a.size();j++){
            mp[j-i+1][hsh1.q(i+1,j+1)] = i+1;
            //for(int e = i+1;e<=j;e++){
                //long long lol1 = hsh1.q(i+1,e);
                //long long lol2 = hsh1.q(e+1,j+1);
                //lol2*=hsh1.p[e-i];
                //lol2%=hsh1.mod;mp[j-i+1][(lol1+lol2)%hsh1.mod] = i+1;
            //}
        }
    }
    for(int i = 0;i<b.size();i++){
        for(int j = i;j<b.size();j++){
            if(mp[j-i+1][hsh2.q(i+1,j+1)]&&ans<(j-i+1)){
                ans = j-i+1;
                st2 = i+1;
                st1 = mp[j-i+1][hsh2.q(i+1,j+1)];
            }
            if(mp[j-i+1][hsh3.q(lenB-j,lenB-i)]&&ans<(j-i+1)){
                st2 = i+1;
                ans = j-i+1;
                st1 = mp[j-i+1][hsh3.q(lenB-j,lenB-i)];
            }
        }
    }
    cout<<ans<<endl;
    cout<<st1-1<<" "<<st2-1<<endl;
}
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... |