QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#317109#7302. Walk of Length 6rgnerdplayer#AC ✓20ms8008kbC++203.2kb2024-01-28 15:18:582024-01-28 15:18:58

Judging History

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

  • [2024-01-28 15:18:58]
  • 评测
  • 测评结果:AC
  • 用时:20ms
  • 内存:8008kb
  • [2024-01-28 15:18:58]
  • 提交

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