QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#328488 | #7881. Computational Complexity | wcyQwQ | WA | 234ms | 23992kb | C++14 | 2.4kb | 2024-02-15 20:27:06 | 2024-02-15 20:27:06 |
Judging History
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'