QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#386475#8340. 3 SumJerryTclRE 0ms3788kbC++202.3kb2024-04-11 17:13:382024-04-11 17:13:38

Judging History

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

  • [2024-09-20 10:20:30]
  • hack成功,自动添加数据
  • (/hack/848)
  • [2024-04-11 17:13:38]
  • 评测
  • 测评结果:RE
  • 用时:0ms
  • 内存:3788kb
  • [2024-04-11 17:13:38]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
using int64 = long long;
int main() {
    cin.tie(0)->sync_with_stdio(0);
    int n, K, ans = 0; cin >> n >> K;
    vector<string> s(n + 1); s[0].assign(K, 9);
    for(int i = 1; i <= n; s[i++].resize(K)) {
        cin >> s[i], reverse(s[i].begin(), s[i].end());
        for(char &ch : s[i]) ch -= 48;
        const int l = (int)s[i].size() - K;
        for(int w = l - 1; w >= 0; ) {
            s[i][w] += s[i][w + K], s[i][w + K] = 0;
            if(s[i][w] >= 10) s[i][w] -= 10, ++s[i][w + 1];
            while(w >= 0 && !s[i][w + K]) --w;
        }
    }
    vector<vector<bitset<500>>> r(n + 1);
    for(auto &it : r) it.resize(n + 1);
    for(int i = 1; i <= n; ++i)
        for(int j = 1; j <= n; ++j) r[i][j].set();
    const auto &check = [&](const int64 mod) {
        unordered_map<int64, bitset<500>> M;
        vector<int64> t(n + 1);
        for(int i = 0, j; i <= n; t[i++] %= mod) {
            assert(s[i].size() == K);
            for(j = K - 1; j >= 3; j -= 4)
                t[i] = (t[i] * 10000 + s[i][j] * 1000 \
                    + s[i][j - 1] * 100 + s[i][j - 2] * 10 + s[i][j - 3]) % mod;
            while(j >= 0) t[i] = t[i] * 10 + s[i][j--];
        }
        const auto &add = [&](int64 x, int64 y)
            { return x + y >= mod ? x + y - mod : x + y; };
        const auto &sub = [&](int64 x, int64 y)
            { return x - y < 0 ? x - y + mod : x - y; };
        for(int i = 1; i <= n; ++i) {
            M[t[i]].set(i);
            for(int j = i; j <= n; ++j) {
                const int64 k = add(t[i], t[j]);
                const int64 v0 = k ? sub(t[0], k) : 0;
                const int64 v1 = add(t[0], v0);
                if(M.count(v0) && M.count(v1))
                    r[i][j] &= M[v0] | M[v1];
                else if(M.count(v0)) r[i][j] &= M[v0];
                else if(M.count(v1)) r[i][j] &= M[v1];
                else r[i][j].reset();
            }
        }
    };
    check(0x66ccff'ff0000 + 43);
    check(0x66ccff'ff0000 + 61);
    check(0x66ccff'ff0000 + 157);
    check(0x66ccff'ff0000 + 215);
    check(0x66ccff'ff0000 + 263);
    for(int i = 1; i <= n; ++i)
        for(int j = i; j <= n; ++j)
            ans += r[i][j].count(); printf("%d\n", ans);
}

詳細信息

Test #1:

score: 100
Accepted
time: 0ms
memory: 3788kb

input:

4 1
0
1
10
17

output:

3

result:

ok 1 number(s): "3"

Test #2:

score: -100
Runtime Error

input:

500 859
7118711592236878297922359501613604144948355616986970837340677671376753603836852811886591300370143151943368529129749813118476151865844255212534355441611481420938483178075143062691345257288242460282715389758789648541099090735875617822348551942134616963557723055980260082230902505269975518146286...

output:


result: