QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#843893#9970. Looping RPSucup-team3608#WA 1ms3816kbC++232.5kb2025-01-05 06:35:502025-01-05 06:35:50

Judging History

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

  • [2025-01-05 06:35:50]
  • 评测
  • 测评结果:WA
  • 用时:1ms
  • 内存:3816kb
  • [2025-01-05 06:35:50]
  • 提交

answer

#include <bits/stdc++.h>
#define st first
#define nd second
using lint = long long;
constexpr int mod = 998244353;
constexpr int inf = 0x3f3f3f3f;
constexpr lint linf = 0x3f3f3f3f3f3f3f3f;
using namespace std;

vector<int> prefix_function(const string& S) {
	vector<int> fail = {-1}; fail.reserve(S.size());
	for (int i = 0; i < int(S.size()); ++i) {
		int j = fail.back();
		while (j != -1 && S[i] != S[j]) j = fail[j];
		fail.push_back(j+1);
	}
	return fail;
}

int main(){
    cin.tie(nullptr)->sync_with_stdio(false);
    int n;
    cin>>n;
    vector<string>s(n);
    vector<vector<int>>kmp(n);
    for(int i=0;i<n;i++) cin>>s[i], kmp[i] = prefix_function(s[i]);
    array<int, 3>iden = {-1, -1, -1};
    vector<array<int, 3>>trie(1, iden);
    vector<int>f(1), h(1), id(1, -1), period(1);
    vector<vector<int>>v(1);
    for(int i=0;i<n;i++){
        int cur = 0;
        vector<int>states(1);
        int sz = (int)s[i].size();
        for(int j=0;j<sz;j++){
            char ch = s[i][j];
            int c = 0;
            if(ch == 'K') c = 0;
            if(ch == 'P') c = 1;
            if(ch == 'N') c = 2;
            if(trie[cur][c] == -1){
                trie[cur][c] = (int)trie.size();
                trie.push_back(iden);
                v.push_back({});
                f.push_back(0);
                id.push_back(i);
                period.push_back(0);
                h.push_back(j + 1);
            }
            cur = trie[cur][c];
            states.push_back(cur);
            period[cur] = states[j + 1 - kmp[i][j + 1]];
            f[cur]++;
        }
        int per = sz - kmp[i][sz];
        if(sz % per) v[cur].push_back(h[cur]);
        else v[period[cur]].push_back(h[period[cur]]);
    }
    int sz = (int)trie.size();
    for(auto &vcur : v){
        sort(vcur.begin(), vcur.end());
    }
    lint ans = 0;
    for(int i=0;i<sz;i++){
        auto [a, b, c] = trie[i];
        lint x = (a == -1) ? 0 : f[a];
        lint y = (b == -1) ? 0 : f[b];
        lint z = (c == -1) ? 0 : f[c];
        if(i){
            int back = period[i]; 
            int rest = h[i] % h[back];
            int num = int(upper_bound(v[back].begin(), v[back].end(), h[i]) - v[back].begin());
            char ch = s[id[back]][rest];
            if(ch == 'K') x += num;
            if(ch == 'P') y += num;
            if(ch == 'N') z += num;
        }
        ans += x * y * z;
    }
    cout<<ans<<"\n";
    



    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 1ms
memory: 3816kb

input:

6
P
PN
KK
N
PKK
PN

output:

6

result:

ok 1 number(s): "6"

Test #2:

score: -100
Wrong Answer
time: 0ms
memory: 3624kb

input:

10
KKKNP
KNKPPKNK
KNKPP
KNKPPKN
KKKN
NNKNNNKNNNKNNNKNNNKNNNKNNNKNNPN
NNKN
NPPN
NNKNNNKNNNKNNNKNNNKNNNKNNNK
KKKNN

output:

1

result:

wrong answer 1st numbers differ - expected: '3', found: '1'