QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#441781#8530. Cowntact Tracingarbuzick26.086957 910ms198408kbC++205.6kb2024-06-14 18:02:342024-06-14 18:02:34

Judging History

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

  • [2024-06-14 18:02:34]
  • 评测
  • 测评结果:26.086957
  • 用时:910ms
  • 内存:198408kb
  • [2024-06-14 18:02:34]
  • 提交

answer

#include <bits/stdc++.h>
#define int long long

using namespace std;

constexpr int maxn = 1e5 + 5, inf = 1e9 + 7;

vector<int> g[maxn];

int mn_dist[maxn];

// int dp1[maxn][maxn], dp2[maxn][maxn];

deque<int> dp1[maxn], dp2[maxn];

int used[maxn];

int dp_ans[maxn];

int t = 0;

int get(deque<int> &dq, int pos) {
    if (pos < dq.size()) {
        return dq[pos];
    }
    return 0;
}

void dfs(int v, int nights, int prv = -1LL) {
    used[v] = t;
    vector<int> kids;
    for (auto u : g[v]) {
        if (used[u] < t) {
            dfs(u, nights, v);
            kids.push_back(u);
        }
    }
    sort(kids.begin(), kids.end(), [&](int a, int b) {
        return dp1[a].size() > dp1[b].size();
    });
    if (kids.empty()) {
        dp1[v].push_back(inf);
        if (mn_dist[v] > nights) {
            dp1[v][0] = 1;
        }
        dp2[v].push_back(0);
        dp_ans[v] = dp1[v][0];
        return;
    }
    swap(dp1[v], dp1[kids[0]]);
    dp1[v].push_front(inf);
    if (dp1[v].size() > nights + 1) {
        dp1[v].pop_back();
    }
    if (mn_dist[v] > nights) {
        dp1[v][0] = 1;
        for (auto u : kids) {
            if (nights == 0) {
                dp1[v][0] += dp_ans[u];
            } else {
                dp1[v][0] += get(dp2[u], nights - 1);
            }
        }
    }
    int mx = 0;
    for (int d = 1; d < (int)dp1[v].size(); ++d) {
        int sum = 0;
        bool fl = false;
        for (auto u : kids) {
            if (u == kids[0]) {
                continue;
            }
            if (dp1[u].size() >= d) {
                fl = true;
            }
            if (d == nights) {
                sum += dp_ans[u];
            } else {
                if (dp2[u].size() <= nights - d - 1) {
                    break;
                }
                sum += get(dp2[u], nights - d - 1);
            }
        }
        if (!fl) {
            break;
        }
        mx = d;
        dp1[v][d] += sum;
        // cout << "!" << sum << ' ';
        if (d == nights) {
            sum += dp_ans[kids[0]];
        } else {
            sum += get(dp2[kids[0]], nights - d - 1);
        }
        for (auto u : kids) {
            if (u == kids[0]) {
                continue;
            }
            if (d == nights) {
                sum -= dp_ans[u];
            } else {
                sum -= get(dp2[u], nights - d - 1);
            }
            if (dp1[u].size() <= d - 1) {
                break;
            }
            dp1[v][d] = min(dp1[v][d], get(dp1[u], d - 1) + sum);
            if (d == nights) {
                sum += dp_ans[u];
            } else {
                sum += get(dp2[u], nights - d - 1);
            }
        }
    }
    for (auto u : kids) {
        if (u == kids[0]) {
            continue;
        }
        if (nights < (int)dp1[v].size() && mx < nights) {
            dp1[v][nights] += dp_ans[u];
        }
        // nights - d - 1 < sz
        // d > nights - 1 - sz
        for (int d = nights - 1 - (int)dp2[u].size(); d < (int)dp1[v].size() && d < nights; ++d) {
            dp1[v][d] += get(dp2[u], nights - d - 1);
        }
    }
    swap(dp2[v], dp2[kids[0]]);
    dp2[v].push_front(0);
    if (dp2[v].size() > nights + 1) {
        dp2[v].pop_back();
    }
    for (auto u : kids) {
        dp2[v][0] += dp_ans[u];
    }
    for (int d = 1; d < (int)dp2[v].size(); ++d) {
        for (int i = 1; i < (int)kids.size(); ++i) {
            dp2[v][d] += get(dp2[kids[i]], d - 1);
            if (dp2[kids[i]].size() < d - 1) {
                break;
            }
        }
    }

    for (int d = 1; d < (int)dp1[v].size(); ++d) {
        dp1[v][d] = min(dp1[v][d], dp1[v][d - 1]);
    }
    dp_ans[v] = dp1[v].back();
    dp2[v][0] = min(dp2[v][0], dp1[v].back());
    for (int i = 1; i < (int)dp2[v].size(); ++i) {
        dp2[v][i] = min(dp2[v][i], dp2[v][i - 1]);
    }
}

void solve() {
    int n;
    cin >> n;
    string s;
    cin >> s;
    for (int i = 0; i < n; ++i) {
        mn_dist[i] = inf;
    }
    for (int i = 0; i < n - 1; ++i) {
        int a, b;
        cin >> a >> b;
        a--, b--;
        if (s[a] == '1' && s[b] == '1') {
            g[a].push_back(b);
            g[b].push_back(a);
        } else {
            mn_dist[a] = 1;
            mn_dist[b] = 1;
        }
    }
    queue<int> q;
    for (int i = 0; i < n; ++i) {
        if (s[i] == '1' && mn_dist[i] == 1) {
            q.push(i);
        }
    }
    while (!q.empty()) {
        int v = q.front();
        q.pop();
        for (auto u : g[v]) {
            if (mn_dist[u] > mn_dist[v] + 1) {
                mn_dist[u] = mn_dist[v] + 1;
                q.push(u);
            }
        }
    }
    int qs;
    cin >> qs;
    while (qs--) {
        int nights;
        cin >> nights;
        for (int i = 0; i < n; ++i) {
            if (s[i] == '1') {
                dp1[i].clear();
                dp2[i].clear();
            }
        }
        t++;
        int ans = 0;
        for (int i = 0; i < n; ++i) {
            if (s[i] == '1' && used[i] < t) {
                dfs(i, nights);
                if (dp_ans[i] >= inf) {
                    ans = -1;
                    break;
                }
                ans += dp_ans[i];
            }
        }
        cout << ans << '\n';
    }
}

signed main() {
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    int t = 1;
    // cin >> t;
    while (t--) {
        solve();
    }
    return 0;
}

详细

Test #1:

score: 4.34783
Accepted
time: 27ms
memory: 138936kb

input:

5
11111
1 2
2 3
3 4
4 5
6
5
4
3
2
1
0

output:

1
1
1
1
2
5

result:

ok 6 lines

Test #2:

score: 4.34783
Accepted
time: 24ms
memory: 140940kb

input:

10
1111111111
1 2
2 3
2 4
2 5
2 6
6 7
7 8
8 9
9 10
11
0
1
2
3
4
5
6
7
8
9
10

output:

10
3
2
1
1
1
1
1
1
1
1

result:

ok 11 lines

Test #3:

score: 4.34783
Accepted
time: 23ms
memory: 139252kb

input:

5
11100
1 2
2 3
3 4
4 5
6
0
1
2
3
4
5

output:

3
1
1
-1
-1
-1

result:

ok 6 lines

Test #4:

score: 4.34783
Accepted
time: 30ms
memory: 138936kb

input:

10
1101111111
6 4
6 7
4 3
4 2
7 9
9 5
5 1
2 8
2 10
11
2
9
5
0
3
6
10
8
7
1
4

output:

2
-1
-1
9
-1
-1
-1
-1
-1
3
-1

result:

ok 11 lines

Test #5:

score: 4.34783
Accepted
time: 23ms
memory: 140732kb

input:

10
1101011111
7 8
8 2
2 10
10 9
9 4
8 1
10 6
6 3
3 5
11
4
8
6
0
5
3
7
9
10
1
2

output:

-1
-1
-1
8
-1
2
-1
-1
-1
3
2

result:

ok 11 lines

Test #6:

score: 0
Time Limit Exceeded

input:

100000
11111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:


result:


Test #7:

score: 0
Time Limit Exceeded

input:

100000
11111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:


result:


Test #8:

score: 4.34783
Accepted
time: 512ms
memory: 180876kb

input:

100000
11111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:

100000
33334
33333
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1

result:

ok 20 lines

Test #9:

score: 0
Wrong Answer
time: 28ms
memory: 139148kb

input:

400
11111111101111110011101111111111011111111111111111111111111111111111111111110111111111111111111101111111011111111101111111111111110111111111110110101111111111111111111111111011111111111111110111111111111011111111111111111111110111101111101110111111010011011111111111011111101111110110111111111111...

output:

-1
-1
15
-1
77
-1
16
24
36
363
21
45
-1
-1
-1
-1
-1
-1
-1
-1

result:

wrong answer 3rd lines differ - expected: '11', found: '15'

Test #10:

score: 0
Wrong Answer
time: 31ms
memory: 140780kb

input:

400
11101111111111111111111110110111111111111111011111111111111011111111111111111010111111111110110111011111101111111111111101111111111010111111111111111111111111111111111111101111111111111110111111111111111111111111111111111111111111101011111111111111111110111101111111111111110111111111111111101111...

output:

-1
-1
48
-1
25
5
-1
-1
157
93
-1
13
-1
4
-1
4
374
-1
-1
-1

result:

wrong answer 3rd lines differ - expected: '37', found: '48'

Test #11:

score: 0
Wrong Answer
time: 35ms
memory: 138848kb

input:

400
11010111101110111110111011010111101011011001111110101101000100011111110101011011011111011110111111111000011110101110011100111111101111101011101110111111111001100111111101101111011011101111111111011101110111111111111011111110111111000111111111111111111111010111101101111111111110111101101110011110...

output:

3
8
4
9
8
-1
-1
3
5
5
10
15
33
13
-1
66
21
-1
13
7

result:

wrong answer 2nd lines differ - expected: '7', found: '8'

Test #12:

score: 0
Runtime Error

input:

6000
1110011111111111110111111111111111111011011111011110111111110111101011111111110111111110110111111111111111111111111111111111111111101111011111111111111111111011111111111111111111111111111111111111111111111110111111111111111111111111011111111111011111101101111111111111111111111111111111110111111...

output:


result:


Test #13:

score: 0
Wrong Answer
time: 48ms
memory: 140788kb

input:

6000
1111111110011111111101111111111101111111111110011111111011111111111111111110110110011011111110111110111111101111111011110111111111101111111111111001111101110111110111111111111111111111111111111010111111111111111101111111110111111111111111111011111111111111111111111111101111111111010111110111111...

output:

-1
-1
-1
-1
-1
16
-1
58
16
-1
397
117
1258
-1
-1
33
-1
-1
23
-1

result:

wrong answer 6th lines differ - expected: '10', found: '16'

Test #14:

score: 0
Wrong Answer
time: 128ms
memory: 140020kb

input:

6000
1101111110111110101111111111111111111110100111111111111111110111101111111111111111111111111111111111111001111111111111111111111111111111111011111111011110111111110111111111110011111111111111111111111111111111110111111111101111111111100111111111110111110111111011011111110101111111111101111001111...

output:

30
5
6
20
4
28
6
3
8
6
7
-1
35
6
5
6
6
5
12
5

result:

wrong answer 1st lines differ - expected: '29', found: '30'

Test #15:

score: 0
Runtime Error

input:

100000
11111111101111111101111011100111111011111101000111011001111010011010111110101001110111111110111111110011111111111111110110111110111111110100111011111111111011111101111111001111101101111011010110110011010111111011111111111011111011110110110111111011111001100100011011111111100011010110111011110...

output:


result:


Test #16:

score: 0
Wrong Answer
time: 512ms
memory: 162816kb

input:

100000
11111100010011111111001101110011001111000111010011101100101100011101111101010011111111000101111111111111011110011110110111101111101101111011110111001110111111101101111111111101011110101111111111011110111110111111111111011101111111110110111011110011111111101110111011110111111111110001111011111...

output:

1
16860
13
-1
-1
-1
-1
-1
4
49
1
-1
-1
-1
1
1
-1
5191
-1
-1

result:

wrong answer 2nd lines differ - expected: '13015', found: '16860'

Test #17:

score: 0
Wrong Answer
time: 910ms
memory: 161208kb

input:

100000
11111111111111111111111111111110101111111011111111111011111111111101111111101111111111111101111111111111111111111111111111101101111111111111111111101111101001111111111110111111110111111110111110111111111111111111111011111101111011101011111111111111111111111111110111111101111111110111101111110...

output:

-1
127
80
-1
210
122
82
105
-1
86
949
102
157
-1
586
96
-1
136
119
82

result:

wrong answer 2nd lines differ - expected: '120', found: '127'

Test #18:

score: 0
Wrong Answer
time: 643ms
memory: 166416kb

input:

100000
11111111111111011111111111011101111111111111111111111111111101111001111111111010111110111111111110111111111011111111111011111111111111111111111111011111111111111111111111011111111111110011111110111111111110111111111101111111111111111111111111111101111111110111111101111101111111111111101111111...

output:

263
460
14
1
1
1
1
21076
-1
1
1
1
-1
12018
2
-1
-1
-1
1
-1

result:

wrong answer 1st lines differ - expected: '208', found: '263'

Test #19:

score: 0
Time Limit Exceeded

input:

100000
11111111111111111111111111110111111111111001111111111111111111110111110111111111111111101111111111111111011110111111111111110011111111111110010111101100111111111111011111111111111111111011111110011111111101010111111111011111111110111111001111011111111111111111111111111111111111111111111111111...

output:

53
46
38
105
64
151
-1
37
46
41
71
94
791
50
425
55
-1
251
-1
153

result:


Test #20:

score: 0
Wrong Answer
time: 663ms
memory: 166932kb

input:

100000
11111111111111111110101111111111111011110101111111111011111111110111111111111111011111111111100111111101111111111111101101011111111111111111111111111111111111111111111111111011111110111111111111111111011111111111111111111111111111111111111111111101111111101111111111111111111011101111111111111...

output:

290
162
3
-1
875
503
38157
-1
3
-1
-1
-1
90
3
-1
3
4
21370
3
-1

result:

wrong answer 1st lines differ - expected: '209', found: '290'

Test #21:

score: 0
Runtime Error

input:

100000
00110111111011100111110111000111101111101001010100110101111001111111100011100110001111101100110110010011001011101011110111101011111111111110111101101111111111101110011111001111111111111101111111010111011010101111011110011111101101101010111011011111010110110010111100011010111101110010111110111...

output:


result:


Test #22:

score: 0
Wrong Answer
time: 544ms
memory: 198408kb

input:

100000
11011111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:

99999
99996
99995
99995
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1

result:

wrong answer 2nd lines differ - expected: '49999', found: '99996'

Test #23:

score: 0
Time Limit Exceeded

input:

99901
111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:


result: