QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#210668 | #61. Cut Cut Cut! | fstqwq | WA | 92ms | 21992kb | C++14 | 1.6kb | 2023-10-11 18:31:18 | 2023-10-11 18:31:20 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
typedef long double LD;
typedef pair <int, int> pii;
typedef vector <LL> vec;
const int N = 3e5 + 5;
const int MOD = 1e9 + 7;
mt19937 rng(MOD - 1);
LL inv (LL x) {
LL ret = 1;
while (x > 1) {
ret *= MOD - MOD / x;
ret %= MOD;
x = MOD % x;
}
return ret;
}
int n, m, d;
struct basis {
vector <vec> a;
basis () {}
void add (vec v) {
for (int i = 0; i < d; i++) if (v[i]) {
LL w = inv(v[i]);
for (int k = 0; k < d; k++) (v[k] *= w) %= MOD;
if (!a[i].size()) {
a[i] = v;
break;
} else {
for (int k = 0; k < d; k++) (v[k] -= a[i][k]) %= MOD;
}
}
}
int rank() {
int cnt = 0;
for (auto v : a) if (v.size()) cnt++;
return cnt;
}
};
vector <int> E[N];
basis p[N];
void work() {
cin >> n >> m;
for (int i = 1; i <= m; i++) {
int u, v;
cin >> u >> v;
E[u].push_back(v);
}
d = (int) E[1].size();
for (int i = 2; i <= n; i++) p[i].a.resize(d);
int c = 0;
for (auto i : E[1]) {
vec tmp(d);
tmp[c++] = 1;
p[i].add (tmp);
}
for (int x = 2; x <= n; x++) {
for (auto to : E[x]) {
vec tmp(d);
for (auto &v : p[x].a) if (v.size()) {
int w = int(rng() % int(1e9)) + 123;
for (int i = 0; i < d; i++) {
(tmp[i] += w * v[i]) %= MOD;
}
}
p[to].add(tmp);
}
}
for (int i = 2; i <= n; i++) {
printf("%d%c", p[i].rank(), i == n ? '\n' : ' ');
}
}
int main() {
ios::sync_with_stdio(false); cin.tie(0);
int T = 1;
// cin >> T;
for (int ca = 1; ca <= T; ca ++) {
work();
}
}
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 17752kb
input:
3 3 1 2 1 3 2 3
output:
1 2
result:
ok 2 number(s): "1 2"
Test #2:
score: 0
Accepted
time: 3ms
memory: 17716kb
input:
8 8 1 2 1 3 1 5 2 4 2 5 3 6 4 5 7 8
output:
1 1 1 2 1 0 0
result:
ok 7 numbers
Test #3:
score: 0
Accepted
time: 0ms
memory: 17784kb
input:
20 70 3 18 14 16 8 10 5 7 2 14 10 18 14 15 17 19 18 20 4 6 3 20 16 17 6 7 6 17 6 19 5 19 12 16 18 19 13 19 13 19 8 9 15 17 8 9 1 7 5 18 6 14 2 17 4 20 12 16 9 20 2 7 6 19 12 13 6 7 1 5 19 20 9 14 13 14 16 17 17 20 9 16 1 6 12 15 2 8 1 3 4 19 1 4 9 13 14 15 15 20 17 18 14 19 13 14 2 5 7 14 7 18 10 16...
output:
0 1 1 1 2 4 0 1 0 0 1 2 5 3 3 4 6 6 6
result:
ok 19 numbers
Test #4:
score: 0
Accepted
time: 0ms
memory: 17824kb
input:
100 1000 26 51 88 93 96 97 55 92 49 60 89 92 81 84 87 95 80 96 33 81 48 73 12 91 71 86 89 90 33 78 13 100 60 89 45 48 98 100 10 43 40 50 13 29 96 99 83 92 84 85 20 39 97 100 41 76 51 71 28 61 2 80 57 89 58 83 10 30 21 85 1 21 86 95 1 65 66 78 57 91 30 41 46 72 59 64 59 79 17 33 68 79 45 78 8 91 12 7...
output:
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0 0 0 1 1 0 1 1 1 1 1 1 2 3 0 1 3 3 0 2 4 1 4 3 2 1 3 1 4 4 3 2 3 4 4 3 4 4 4 5 2 5 3 7 7 5 6 4 7 7 6 7 6 4 5 7 7 7 6 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7
result:
ok 99 numbers
Test #5:
score: 0
Accepted
time: 39ms
memory: 18736kb
input:
2000 50000 74 1663 975 1279 632 1796 1137 1386 121 1557 627 678 482 1961 1554 1654 1 388 1940 1971 512 1665 675 1279 946 1834 1473 1645 732 1620 169 552 1996 1997 1549 1982 1678 1788 1282 1831 1084 1455 1166 1566 380 854 1087 1263 763 1569 234 864 1166 1475 47 1680 194 350 1939 1949 8 1028 357 1234 ...
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 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 1999 numbers
Test #6:
score: 0
Accepted
time: 34ms
memory: 18908kb
input:
2000 50000 1078 1288 298 1803 1715 1954 547 1412 1060 1730 1077 1855 1685 1947 1416 1804 1469 1737 1637 1888 1048 1462 162 237 1655 1885 492 963 1 811 1598 1948 261 1353 441 1531 1829 1838 170 1189 1848 1996 705 1909 931 1724 493 574 1146 1412 1062 1730 102 206 49 615 1777 1931 106 1808 1545 1789 11...
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 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 1999 numbers
Test #7:
score: 0
Accepted
time: 23ms
memory: 18784kb
input:
2000 50000 347 505 1265 1885 1170 1773 1126 1942 375 1060 1463 1622 1661 1972 321 1956 69 1968 518 1896 1348 1654 166 1060 1 907 1520 1733 3 1085 1886 1954 1532 1603 821 1248 654 1899 1477 1595 792 1504 410 496 1421 1955 77 1201 1410 1442 1974 1981 1081 1470 718 904 687 1275 1693 1977 2 526 398 585 ...
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 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 1999 numbers
Test #8:
score: -100
Wrong Answer
time: 92ms
memory: 21992kb
input:
2000 50000 1097 1906 350 533 1144 1809 49 1971 1498 1655 261 808 716 834 40 60 692 1664 292 602 1383 1728 1127 1395 1441 1602 761 1213 1671 1875 978 1683 505 646 798 1663 1359 1542 1960 1961 1258 1800 121 554 1 742 1403 1566 769 1397 475 1576 625 806 1468 1611 1943 1972 181 769 1816 1913 1 1846 290 ...
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 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 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:
wrong answer 1208th numbers differ - expected: '11', found: '12'