Submission #1102764

#TimeUsernameProblemLanguageResultExecution timeMemory
1102764vjudge1Palindromes (APIO14_palindrome)C++17
68 / 100
33 ms65680 KiB
#include <bits/stdc++.h>

using namespace std;
using ll = long long;

struct PAM {
    static constexpr int ALPHABET_SIZE = 26;
    struct Node {
        int len, fail;
        array<int, ALPHABET_SIZE> next;
        Node() : len{}, fail{}, next{} {}
    };
    vector<int> s;
    vector<Node> t;
    int lst;  // 用來追踪當前回文節點
    PAM() { init(); }
    void init() {
        t.assign(2, Node());
        s.clear(); 
        t[1].len = -1; // 奇數根節點
        t[0].len = 0, t[0].fail = 1; // 偶數根節點
        lst = 1;  // 初始 lst 為奇數根
    }
    int newNode() {
        t.emplace_back();
        return t.size() - 1;
    }
    int extend(int p, int c) {
        int n = s.size();
        s.push_back(c);
        while (s[n - t[p].len - 1] != c)
            p = t[p].fail;
        if (!t[p].next[c]) {
            int r = newNode();
            t[r].len = t[p].len + 2;
            int cur = t[p].fail;
            while (s[n - t[cur].len - 1] != c)
                cur = t[cur].fail;
            t[r].fail = t[cur].next[c];
            t[p].next[c] = r;
        }
        return t[p].next[c];
    }
    void build_count(vector<int>& cnt) {
        // 計數累加到 fail 鏈
        for (int i = t.size() - 1; i > 1; --i) {
            cnt[t[i].fail] += cnt[i];
        }
    }
};

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    string s;
    cin >> s;
    int n = s.length();
    vector<int> last(n + 1);
    vector<int> cnt(n + 1);  // 用於記錄每個回文節點的出現次數
    PAM pam;
    pam.init();
    for (int i = 0; i < n; i++) {
        pam.lst = pam.extend(pam.lst, s[i] - 'a');
        cnt[pam.lst]++;  // 統計每個回文節點的次數
    }

    pam.build_count(cnt);  // 累加 fail 鏈上的出現次數

    ll ans = 0;
    for (int i = 2; i < pam.t.size(); i++) {  
        ans = max(ans, 1LL * pam.t[i].len * cnt[i]);
    }

    cout << ans << "\n";

    return 0;
}

Compilation message (stderr)

palindrome.cpp: In function 'int main()':
palindrome.cpp:71:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<PAM::Node>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   71 |     for (int i = 2; i < pam.t.size(); i++) {
      |                     ~~^~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...