QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#328488#7881. Computational ComplexitywcyQwQWA 234ms23992kbC++142.4kb2024-02-15 20:27:062024-02-15 20:27:06

Judging History

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

  • [2024-02-15 20:27:06]
  • 评测
  • 测评结果:WA
  • 用时:234ms
  • 内存:23992kb
  • [2024-02-15 20:27:06]
  • 提交

answer

#include <bits/stdc++.h>
#define L(i, j, k) for (int i = (j); i <= (k); i++)
#define R(i, j, k) for (int i = (j); i >= (k); i--)

using namespace std;
using LL = long long;

const int N = 15, M = 1e6 + 10;
const LL V = 1e15;
LL f[N], g[N], mod;
int T;
map<LL, LL> dF, dG;
map<LL, int> cc;

template<class T = int> T read() {
    T x = 0, y = 1;
    char c = getchar();
    while (c < '0' || c > '9') {
        if (c == '-') {
            y = -1;
        }
        c = getchar();
    }
    while (c >= '0' && c <= '9') {
        x = x * 10 + c - '0';
        c = getchar();
    }
    return x * y;
}

void push(LL cur, vector<LL> &v) {
    if (cc[cur]) {
        return;
    }
    cc[cur] = 1;
    if (cur >= 14) {
        v.emplace_back(cur);
    }
    for (LL p : {2, 3, 5, 7}) {
        if (cur <= V / p) {
            push(cur * p, v);
        }
    }
}

LL getF(LL p) {
    return dF.find(p) == dF.end() ? 0 : dF[p];
}

LL getG(LL p) {
    return dG.find(p) == dG.end() ? 0 : dG[p];
}

int main() {
    f[0] = read(), g[0] = read(), T = read();
    mod = read<LL>();
    L(i, 1, 13) {
        f[i] = max((LL)i, g[i / 2] + g[i / 3] + g[i / 5] + g[i / 7]);
        g[i] = max((LL)i, f[i / 2] + f[i / 3] + f[i / 4] + f[i / 5]);
        dF[i] = (f[i] - f[i - 1]) % mod;
        dG[i] = (g[i] - g[i - 1]) % mod;
    }
    vector<LL> vec;
    push(1, vec);
    push(11, vec);
    push(13, vec);
    sort(vec.begin(), vec.end());
    for (auto p : vec) {
        dF[p] = (!(p % 2) * getG(p / 2) + !(p % 3) * getG(p / 3) + !(p % 5) * getG(p / 5) + !(p % 7) * getG(p / 7)) % mod;
        dG[p] = (!(p % 2) * getF(p / 2) + !(p % 3) * getF(p / 3) + !(p % 4) * getF(p / 4) + !(p % 5) * getF(p / 5)) % mod;
    }
    int cnt = 0;
    vector<pair<LL, LL>> F, G;
    F.push_back({0, f[0] % mod});
    G.push_back({0, g[0] % mod});
    for (auto t : dF) {
        F.push_back(t);
    }
    for (auto t : dG) {
        G.push_back(t);
    }
    assert(F.size() == G.size());
    L(i, 1, (int)F.size() - 1) {
        (F[i].second += F[i - 1].second) %= mod;
        (G[i].second += G[i - 1].second) %= mod;
    }
    while (T--) {
        LL m = read<LL>();
        printf("%lld %lld\n", (*--upper_bound(F.begin(), F.end(), make_pair(m, V))).second, (*--upper_bound(G.begin(), G.end(), make_pair(m, V))).second);
    }
    return 0;
}

详细

Test #1:

score: 100
Accepted
time: 201ms
memory: 23948kb

input:

1958 920 10 100000000000
0
1
2
3
10
100
200
1000
19580920
20232023

output:

1958 920
3680 7832
10592 9554
17504 11276
50294 64826
784112 893714
1894550 1905470
12057866 12979424
71481494756 48626708512
28127864908 7251681354

result:

ok 20 numbers

Test #2:

score: 0
Accepted
time: 195ms
memory: 23992kb

input:

0 0 10 100000000000
0
1
2
3
4
10
20
30
40
100

output:

0 0
1 1
2 2
3 3
4 4
11 12
25 26
41 41
55 58
162 172

result:

ok 20 numbers

Test #3:

score: 0
Accepted
time: 206ms
memory: 23848kb

input:

2023 2023 10 2023
0
1
2
3
4
5
6
7
8
9

output:

0 0
0 0
0 0
0 0
0 0
0 0
0 0
0 0
0 0
0 0

result:

ok 20 numbers

Test #4:

score: 0
Accepted
time: 210ms
memory: 23992kb

input:

36092 30559 2149 729566623185
909730017626
961811467628
978809456383
494310140318
760462959632
726343527430
220697276132
366336227300
456813204361
569783542145
13854148170
51526515764
564416233246
876430686824
862897449267
956440673661
512777546436
728860125927
799238602356
978766770799
47962348351
...

output:

192287632545 510282654057
513694515018 658644741565
90751152870 6088748556
138070013247 301112114677
224113421002 105290451187
630454127249 196841848259
546918129568 526274849982
226761501362 157889210040
135623074930 620463814922
78467045157 602244472172
51639549042 411354142414
329188915935 306494...

result:

ok 4298 numbers

Test #5:

score: 0
Accepted
time: 213ms
memory: 23932kb

input:

46012 72474 6895 931299293479
635558333906
151352929427
186830308154
201652909474
130684521091
862625793178
335372663856
565394770762
609752364488
636658378167
568072145317
23602174799
74849827839
567735061723
964475612065
721588322843
526921882143
141483206690
794896616456
923141155683
443983986019...

output:

737640936783 269480550026
785950579990 586907405473
274405996613 356240054012
164145774405 803378519477
613956922400 426121843045
509646717167 788278629379
95131481441 672600899832
720839818877 52329269906
131977527669 257593035330
737640936783 269480550026
202443098753 171133839273
188615102144 605...

result:

ok 13790 numbers

Test #6:

score: -100
Wrong Answer
time: 234ms
memory: 23864kb

input:

4625 65696 87448 104757899185
324541097749
340894391228
353710640194
913290645927
500906082550
994613091630
486893604015
755863379632
795242109754
670982629049
89739557323
995677833835
622128974870
291590021762
74643709454
491030939322
504220665415
590951839890
749414110824
908656060298
831415689095...

output:

24017028596 61020984279
90036018081 8518714361
4807132724 94915889679
60642395760 99169995073
45912197521 30663794937
26807208137 73005099296
31855861883 38442189712
61377861921 69296474844
15633158436 24561226404
83188091024 101278210525
92283972576 51782451279
22904017080 27746280119
46615471334 7...

result:

wrong answer 54th numbers differ - expected: '91736000491', found: '-13021898694'