QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#149004#243. Lyndon Substringnameless_storyCompile Error//C++203.7kb2023-08-23 21:39:262023-08-23 21:39:27

Judging History

你现在查看的是最新测评结果

  • [2023-08-23 21:39:27]
  • 评测
  • [2023-08-23 21:39:26]
  • 提交

answer

#include<bits/stdc++.h>

using namespace std;

typedef long long LL;
#define N 30'0000

const valarray<LL> B={233,199},mod={998244353,(LL)1e9+7};
valarray<LL> pw[N];
struct hashstring{
    vector<valarray<LL>> f;
    void build(string s){
        f.resize(s.size()+1);
        f[0]={0,0};
        for (LL i=0;i<s.size();++i){
            auto w=s[i];
            f[i+1]=(f[i]*B+w)%mod;
        }
    }
    valarray<LL> calc(LL i,LL len){
        return (f[i+len]-f[i]*pw[len]%mod+mod)%mod;
    }
};
void init(LL n){
    pw[0]={1,1}; for (LL i=1;i<=n;++i) pw[i]=pw[i-1]*B%mod;
}

bool operator == (const valarray<LL> &a,const valarray<LL> &b){
    if (a.size()!=b.size()) return false;
    for (LL i=0;i<a.size();++i){
        if (a[i]!=b[i]) return false;
    }
    return true;
}

void solve(){
    LL n,m; cin>>n>>m;
    vector<string> s(n);
    vector<hashstring> f(n);
    for (LL i=0;i<n;++i){
        cin>>s[i];
        f[i].build(s[i]);
    }
    vector<vector<LL>> lyndon(n),sim(n);
    vector<LL> ans(n);
    for (LL i=0;i<n;++i){
        auto st=s[i]+'0';
        for (LL lst=-1,cyc=1,j=1;j<st.size();++j){
            if (st[j]>st[j-cyc]) cyc=j-lst;
            else{
                if (st[j]<st[j-cyc]){
                    ans[i]=max(ans[i],cyc);
                    if (j==st.size()-1){
                        sim[i].push_back(lst+1);
                    }
                    for (lst+=cyc;lst<j;lst+=cyc){
                        lyndon[i].push_back(lst);
                    }
                    lst-=cyc;
                    cyc=1;
                    j=lst+1;
                }
            }
        }
    }
    for (LL i=0;i<n;++i){
        LL lst=0;
        for (LL x:lyndon[i]){
            ans[i]=max(ans[i],x-lst);
            lst=x;
        }
    }
    auto calc=[&](LL i,LL j,LL p,LL len){
        if (p+len<=s[i].size()) return f[i].calc(p,len);
        if (p>=s[i].size()) return f[j].calc(p-s[i].size(),len);
        LL t=s[i].size()-p;
        return (f[i].calc(p,t)*pw[len-t]+f[j].calc(0,len-t))%mod;
    };
    auto check=[&](LL i,LL j,LL p1,LL p2,LL len){
        if (calc(i,j,p1,len)==calc(i,j,p2,len)) return false;
        LL l=1,r=len,k=0;
        while (l<=r){
            LL mid=(l+r)>>1;
            if (calc(i,j,p1,mid)==calc(i,j,p2,mid)){
                k=mid;
                l=mid+1;
            }
            else{
                r=mid-1;
            }
        }
        auto c1=(p1+k<s[i].size())?s[i][p1+k]:s[j][p1+k-s[i].size()];
        auto c2=(p2+k<s[i].size())?s[i][p2+k]:s[j][p2+k-s[i].size()];
        return c1<c2;
    };
    while (m--){
        LL i,j; cin>>i>>j; --i; --j;
        LL tmp=max(ans[i],ans[j]);
        LL t=sim[i].back();
        for (LL k=0;k+1<sim[i].size();++k){
            LL l=1,r=s[j].size();
            LL p1=sim[i][k];
            LL p2=sim[i][k+1];
            LL len0=s[i].size()-p2,mx=0;
            if (check(i,j,p1,p2,len0+s[j].size())) t=sim[i][k];
        }
        if (check(i,j,t,s[i].size(),s[j].size())){
            LL l=0,r=lyndon[j].size()-1,pre=0;
            while (l<=r){
                LL mid=(l+r)>>1;
                LL L=mid==0?0:lyndon[j][mid-1]+1;
                LL R=lyndon[j][mid];
                if (check(i,j,t,s[i].size()+L,R-L+1)){
                    pre=lyndon[j][mid]+1;
                    l=mid+1;
                }
                else{
                    r=mid-1;
                }
            }
            tmp=max(tmp,(LL)s[i].size()-t+pre);
        }
        cout<<tmp<<'\n';
    }
}
int main(){
    ios::sync_with_stdio(0); cin.tie(0);
    LL T; cin>>T;
    init(200000);
    while (T--) solve();
}

詳細信息

answer.code: In lambda function:
answer.code:77:61: error: inconsistent types ‘std::valarray<long long int>’ and ‘std::_Expr<std::__detail::_BinClos<std::__modulus, std::_Expr, std::_ValArray, std::__detail::_BinClos<std::__plus, std::_Expr, std::_ValArray, std::__detail::_BinClos<std::__multiplies, std::_ValArray, std::_ValArray, long long int, long long int>, long long int>, long long int>, long long int>’ deduced for lambda return type
   77 |         return (f[i].calc(p,t)*pw[len-t]+f[j].calc(0,len-t))%mod;
      |                ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~