QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#317109 | #7302. Walk of Length 6 | rgnerdplayer# | AC ✓ | 20ms | 8008kb | C++20 | 3.2kb | 2024-01-28 15:18:58 | 2024-01-28 15:18:58 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
using i64 = long long;
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int n;
auto solve = [&]() {
// p2 : 2
// p3 : 12
// p4 : 6
// k13 : 12
// c3 : 24
// c4 : 48
// c3 + c3 : 24
// c4 + diag : 36
// c4 + tail : 12
constexpr int N = 1000;
vector adj(n, bitset<N>());
vector<int> deg(n);
vector f(n, vector<int>(n));
for (int i = 0; i < n; i++) {
string s;
cin >> s;
for (int j = 0; j < n; j++) {
adj[i][j] = s[j] - '0';
}
deg[i] = adj[i].count();
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
f[i][j] = (adj[i] & adj[j]).count();
}
}
vector<i64> cnt(9);
cnt[0] = accumulate(deg.begin(), deg.end(), 0) / 2;
for (int i = 0; i < n; i++) {
if (deg[i] >= 2) {
cnt[1] += deg[i] * (deg[i] - 1) / 2;
}
}
for (int i = 0; i < n; i++) {
if (deg[i] >= 3) {
cnt[3] += deg[i] * (deg[i] - 1) * (deg[i] - 2) / 6;
}
}
for (int i = 0; i < n; i++) {
for (int j = i + 1; j < n; j++) {
if (adj[i][j]) {
cnt[4] += f[i][j];
}
}
}
cnt[4] /= 3;
for (int i = 0; i < n; i++) {
for (int j = i + 1; j < n; j++) {
if (adj[i][j]) {
cnt[2] += (deg[i] - 1) * (deg[j] - 1);
}
}
}
cnt[2] -= 3 * cnt[4];
for (int i = 0; i < n; i++) {
for (int j = i + 1; j < n; j++) {
if (f[i][j] >= 2) {
cnt[5] += f[i][j] * (f[i][j] - 1) / 2;
}
}
}
cnt[5] /= 2;
for (int i = 0; i < n; i++) {
for (int j = i + 1; j < n; j++) {
if (adj[i][j] && f[i][j] >= 2) {
cnt[7] += f[i][j] * (f[i][j] - 1) / 2;
}
}
}
for (int i = 0; i < n; i++) {
int tot = 0;
for (int j = 0; j < n; j++) {
if (i != j && adj[i][j]) {
tot += f[i][j];
}
}
tot /= 2;
if (tot >= 2) {
cnt[6] += 1LL * tot * (tot - 1) / 2;
}
}
cnt[6] -= 2 * cnt[7];
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
if (i == j || f[i][j] < 2 || deg[i] - 2 - adj[i][j] <= 0) {
continue;
}
cnt[8] += f[i][j] * (f[i][j] - 1) / 2 * (deg[i] - 2 - adj[i][j]);
}
}
vector<i64> coef{2, 12, 6, 12, 24, 48, 24, 36, 12};
i64 ans = 0;
for (int i = 0; i < int(cnt.size()); i++) {
ans += coef[i] * cnt[i];
}
cout << ans << '\n';
};
while (cin >> n) {
solve();
}
return 0;
}
这程序好像有点Bug,我给组数据试试?
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3684kb
input:
3 011 101 110 4 0101 1010 0101 1010 6 011111 101111 110111 111011 111101 111110
output:
66 128 14910
result:
ok 3 number(s): "66 128 14910"
Test #2:
score: 0
Accepted
time: 1ms
memory: 3888kb
input:
1 0 2 01 10 3 011 100 100 3 011 101 110 4 0001 0001 0001 1110 4 0101 1001 0001 1110 4 0100 1001 0001 0110 4 0101 1011 0101 1110 4 0110 1001 1001 0110 4 0111 1011 1101 1110 5 01000 10111 01000 01000 01000 5 01111 10001 10000 10000 11000 5 01100 10110 11011 01100 00100 5 01111 10110 11010 11100 10000 ...
output:
0 2 16 66 54 116 36 298 128 732 128 202 408 878 80 172 794 1372 56 372 668 190 2370 142 300 300 100 650 1216 432 4100 250 336 566 1072 988 1602 850 2648 446 1434 4438 160 264 524 1030 130 802 258 362 1380 518 1650 2372 3538 5460 488 106 234 892 1542 482 362 790 1326 2186 288 1176 1784 808 5232 7358 ...
result:
ok 143 numbers
Test #3:
score: 0
Accepted
time: 1ms
memory: 3820kb
input:
20 01110111111111111111 10111111111011111111 11011111101111101111 11101110111011111111 01110111111011011011 11111011101111011110 11111101111111101111 11101110111111111111 11111111011111111111 11011011101111101111 11111111110111010111 10100111111011111111 11111111111101111110 11111111111110111111 111...
output:
11368772 12823048 16678042 17149212 18099376 18616410 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 19138700 191...
result:
ok 50 numbers
Test #4:
score: 0
Accepted
time: 1ms
memory: 3904kb
input:
50 01111111111101010111111110111111111111001110111111 10111111011010111101111111011111111111111111011111 11010101111111111110011110001111111111111111111111 11101111110101111110101111111111111111111101111111 11010111111101101111011111111101111111101111111110 111110111011111111111111111111111111111101...
output:
1250940348 1590514050 1984065786 2169894880 2338139630 2348971408 2399983250 2399983250 2389639440 2389639440 2399983250 2399983250 2399983250 2399983250 2399983250 2399983250 2399983250 2399983250 2399983250 2399983250
result:
ok 20 numbers
Test #5:
score: 0
Accepted
time: 20ms
memory: 7700kb
input:
1000 0110000100111110011111111011111111111111111010111011111111110111111111110111110011101111110111111110110111111111111011111100101111000111011011101111110011111101110110111011100111111101101110101111001011011101011101111101111111111111000110011011010111111111111111111010111011011110010111011111101...
output:
1943182464425962
result:
ok 1 number(s): "1943182464425962"
Test #6:
score: 0
Accepted
time: 17ms
memory: 7936kb
input:
1000 0111101111111111110111111111110011101111111101111011110111111110111011011101111110111111111111111111111111111110111110111110111101110110111111101111111111101101111111011011111111111111011111111111111111111011111111111111111110111111111111101111111101111011111111111111111111111111111000111111111...
output:
4406302098164568
result:
ok 1 number(s): "4406302098164568"
Test #7:
score: 0
Accepted
time: 11ms
memory: 7932kb
input:
1000 0111111111111111111111111111111111111111111111111111111111111111111111111111111111111011111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111010111111111111111111111111111111111111111011111111111111111...
output:
7524709536316820
result:
ok 1 number(s): "7524709536316820"
Test #8:
score: 0
Accepted
time: 15ms
memory: 7700kb
input:
1000 0111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
output:
8841456311725232
result:
ok 1 number(s): "8841456311725232"
Test #9:
score: 0
Accepted
time: 15ms
memory: 7800kb
input:
1000 0111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
output:
8930014130020796
result:
ok 1 number(s): "8930014130020796"
Test #10:
score: 0
Accepted
time: 11ms
memory: 7764kb
input:
1000 0111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
output:
8930204741115000
result:
ok 1 number(s): "8930204741115000"
Test #11:
score: 0
Accepted
time: 7ms
memory: 8008kb
input:
1000 0000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...
output:
55816
result:
ok 1 number(s): "55816"
Test #12:
score: 0
Accepted
time: 11ms
memory: 7996kb
input:
1000 0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...
output:
0
result:
ok 1 number(s): "0"
Extra Test:
score: 0
Extra Test Passed