40分求助

P3955 [NOIP2017 普及组] 图书管理员

Domiss1017 @ 2023-04-09 22:42:15

小数据能过数据一多就死

代码:

#include<bits/stdc++.h>
using namespace std;
int n,q;
string t[1005],x[1005];
int s[1005];
int jiansuo(int n,int m,int dep){
    if(dep==-1){
        return 1;
    }
    if(x[n][dep]==t[m][dep+t[m].size()-s[n]]){
        jiansuo(n,m,dep-1);
    }
    else{
        return 0;
    }
}
int main(){
    cin>>n>>q;
    for(int i=0;i<n;i++){
        cin>>t[i];
    }
    for(int i=0;i<q;i++){
        cin>>s[i]>>x[i];
    }
    for(int i=0;i<n-1;i++){
        for(int j=0;j<n-1;j++){
            if(t[j].size()>t[j+1].size()){
                swap(t[j],t[j+1]);
            }
            else if(t[j].size()==t[j+1].size() && t[j]>t[j+1]){
                swap(t[j],t[j+1]);
            }
        }
    }
    bool ok=0;
    for(int i=0;i<q;i++){
        ok=0;
        for(int j=0;j<n;j++){
            if(jiansuo(i,j,s[i-1])){
                cout<<t[j]<<endl;
                ok=1;
                break;
            }
            if(j==n-1){
                cout<<"-1"<<endl;
                ok=1;
                break;
            }
        }
        if(ok==1) continue;
    }
    return 0;
}

|