QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#863685 | #5188. 鬼街 | xiay | AC ✓ | 8123ms | 1373532kb | C++14 | 3.1kb | 2025-01-19 21:13:13 | 2025-01-19 21:13:24 |
Judging History
answer
#include <bits/stdc++.h>
#define arr(x) array<ll, x>
#define INF 0x3f3f3f3f
#define scanf(...) assert(scanf(__VA_ARGS__))
using namespace std;
using ll = long long;
namespace FastIO {
static char buf[100000], *p1 = buf, *p2 = buf;
#define gc (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 100000, stdin), p1 == p2) ? EOF : *p1++)
inline ll read() {
ll res = 0;
int w = 0, c = gc;
for (; !isdigit(c); c = gc) {
((c == '-') && (w = 1));
}
for (; isdigit(c); c = gc) {
res = (res << 1) + (res << 3) + (c ^ 48);
}
return (w ? -res : res);
}
inline char readC() {
int c = gc;
while (c == '\n' || c == '\r' || c == ' ') {
c = gc;
}
return c;
}
inline string readS() {
string res = "";
int w = 0;
char c = gc;
for (; (c == '\n' || c == '\r' || c == ' ' || c == EOF); c = gc);
for (; !(c == '\n' || c == '\r' || c == ' ' || c == EOF); c = gc) {
res += c;
}
return res;
}
inline double readF() {
double res = 0, tmp = 0.1;
int w = 0;
char c = gc;
for (; !isdigit(c); c = gc) {
((c == '-') && (w = 1));
}
for (; isdigit(c); c = gc) {
res = (res * 10) + (c ^ 48);
}
if (c == '.') {
c = gc;
for (; isdigit(c); c = gc) {
res = res + tmp * (c ^ 48);
tmp *= 0.1;
}
}
return (w ? -res : res);
}
inline void write(ll x, char c = '\n') {
((x < 0) && (putchar('-'), x *= -1));
static int sta[50], top = 0;
do {
sta[top++] = x % 10, x /= 10;
} while (x);
while (top) {
putchar(sta[--top] + 48);
}
putchar(c);
}
};
using namespace FastIO;
const int N = 1e5 + 5;
int n, m;
ll cnt[N];
vector<int> vec[N];
void init(int n) {
for (int i = 2; i <= n; ++i) {
if (!vec[i].size()) {
for (int j = i; j <= n; j += i) {
vec[j].push_back(i);
}
}
}
}
int tot, x[N], tag[N];
ll y[N];
priority_queue<arr(3), vector<arr(3)>, greater<arr(3)>> q[N];
vector<int> ans;
void rebuild(int id) {
ll sum = 0;
for (int i : vec[x[id]]) {
sum += cnt[i];
}
if (sum >= y[id]) {
ans.push_back(id);
tag[id] = -1;
return ;
}
ll val = (y[id] - sum - 1) / vec[x[id]].size() + 1;
++tag[id];
for (int i : vec[x[id]]) {
q[i].push({cnt[i] + val, id, tag[id]});
}
}
void upd(int id) {
while (!q[id].empty() && q[id].top()[0] <= cnt[id]) {
arr(3) tmp = q[id].top(); q[id].pop();
if (tmp[2] ^ tag[tmp[1]]) {
continue;
}
rebuild(tmp[1]);
}
}
signed main() {
#ifdef LOCAL
assert(freopen("test.in", "r", stdin));
assert(freopen("test.out", "w", stdout));
#endif
n = read(), m = read();
init(n);
int lst = 0;
for (int i = 1; i <= m; ++i) {
int op = read(), xt = read();
ll yt = read() ^ lst;
if (op) {
for (int j : vec[xt]) {
yt += cnt[j];
}
++tot;
x[tot] = xt, y[tot] = yt;
rebuild(tot);
}
else {
for (int j : vec[xt]) {
cnt[j] += yt;
upd(j);
}
sort(ans.begin(), ans.end());
write(lst = ans.size(), ' ');
for (int j : ans) {
write(j, ' ');
}
puts("");
ans.clear();
}
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 10684kb
input:
20 9 1 10 2 0 5 0 0 6 1 0 7 1 0 15 1 1 12 3 0 8 0 1 5 0 0 8 2
output:
0 0 0 1 1 0 2 2 3
result:
ok 6 lines
Test #2:
score: 0
Accepted
time: 1ms
memory: 11608kb
input:
5000 5000 1 308 2924116129 1 3201 931426424 1 4398 709387999 0 609 2256581248 0 1566 1777416018 1 4709 1171183682 0 3770 752123966 1 1896 3894906376 0 230 3761076141 1 1345 676968476 1 3116 342409501 0 4948 3143999592 1 2186 2376352094 1 3892 3478048443 0 2773 2100852395 1 2894 2317216575 0 3378 211...
output:
2 2 3 1 1 0 0 2 5 7 0 0 0 1 11 1 4 3 8 9 10 0 0 0 5 13 14 15 17 19 0 0 2 18 20 0 2 16 22 5 6 21 23 24 25 0 0 2 27 29 1 28 2 26 30 0 0 0 0 0 0 1 33 0 0 2 31 32 0 0 2 35 36 0 0 1 37 0 0 0 0 1 39 1 40 0 0 1 42 0 0 2 34 43 0 0 4 44 46 48 49 2 50 5...
result:
ok 2569 lines
Test #3:
score: 0
Accepted
time: 25ms
memory: 15288kb
input:
100000 100000 0 88257 3347892307 1 75731 1809061227 0 16838 427131616 1 37901 3913929645 0 34652 2841091466 1 94967 1193577995 0 88669 2312699947 0 65963 2968268361 0 24727 3935129828 0 85199 4076952986 0 80409 4193957044 1 65125 3928747142 1 46471 976433442 0 40164 1210148974 0 66889 3862378511 1 5...
output:
0 0 0 0 0 0 0 0 0 0 0 0 0 2 7 8 1 9 0 1 12 1 11 2 10 13 6 4 15 16 18 20 21 1 23 0 1 17 0 0 0 1 30 0 0 1 24 0 5 26 28 31 32 34 1 36 1 37 0 0 4 27 29 38 39 2 40 42 5 3 43 45 47 48 2 33 41 1 46 3 49 50 51 0 0 1 52 3 14 44 54 0 0 0 0 0 0 0 3 57 58 60 ...
result:
ok 49859 lines
Test #4:
score: 0
Accepted
time: 229ms
memory: 28656kb
input:
100000 100000 1 100000 686376074 1 99999 1480169272 1 99998 3342696633 1 99997 3780400597 1 99996 987312141 1 99995 1940629988 1 99994 3882419811 1 99993 2620287406 1 99992 117147645 1 99991 4118056210 1 99990 1544011251 1 99989 2856008809 1 99988 1621361290 1 99987 3983397497 1 99986 1989759776 1 9...
output:
37 1777 4119 4466 7328 10001 10481 10796 11973 13694 13747 17453 18447 18452 18710 24307 24353 27219 27867 31925 32241 32807 35929 36485 36515 36920 37737 38555 39865 40243 41097 42861 44559 44895 45518 45572 48590 48809 30 2625 3410 4325 4643 4785 10441 13124 16215 19575 23229 24815 27493 29907 30...
result:
ok 50000 lines
Test #5:
score: 0
Accepted
time: 381ms
memory: 117604kb
input:
100000 100000 1 2 50000 1 4 50000 1 6 50000 1 8 50000 1 10 50000 1 12 50000 1 14 50000 1 16 50000 1 18 50000 1 20 50000 1 22 50000 1 24 50000 1 26 50000 1 28 50000 1 30 50000 1 32 50000 1 34 50000 1 36 50000 1 38 50000 1 40 50000 1 42 50000 1 44 50000 1 46 50000 1 48 50000 1 50 50000 1 52 50000 1 54...
output:
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ...
result:
ok 50000 lines
Test #6:
score: 0
Accepted
time: 22ms
memory: 15004kb
input:
100000 100000 1 71533 1624315381 0 89184 1624315381 1 93680 3158643236 0 66680 3158643236 1 93948 1261724001 0 59949 1261724001 1 42374 1643731476 0 84748 1643731476 1 88256 2309789107 0 38136 2309789107 1 51927 2589008727 0 91100 2589008727 1 37451 2981496542 0 94248 2981496542 1 71333 42228574 0 7...
output:
1 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 1 9 1 10 1 11 1 12 1 13 1 14 1 15 1 16 1 17 1 18 1 19 1 20 1 21 1 22 1 23 1 24 1 25 1 26 1 27 1 28 1 29 1 30 1 31 1 32 1 33 1 34 1 35 1 36 1 37 1 38 1 39 1 40 1 41 1 42 1 43 1 44 1 45 1 46 1 47 1 48 1 49 1 50 1 51 1 5...
result:
ok 49999 lines
Test #7:
score: 0
Accepted
time: 8123ms
memory: 1373532kb
input:
100000 100000 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1 30030 4294967295 1...
output:
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ...
result:
ok 162 lines