QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#811762 | #5683. 大富翁 | thupc_team | AC ✓ | 111ms | 32628kb | C++20 | 2.0kb | 2024-12-13 00:36:26 | 2024-12-13 00:36:34 |
Judging History
answer
#include <bits/stdc++.h>
using i64 = long long;
using u64 = unsigned long long;
using pii = std::pair<int, int>;
#define all(a) a.begin(), a.end()
#define chmin(a, b) a = std::min(a, (b));
#define chmax(a, b) a = std::max(a, (b));
void solve(){
int N;
std::cin >> N;
std::vector<int> v(N);
for(int i = 0; i < N; i++){
std::cin >> v[i];
}
std::vector<std::vector<int> > adj(N);
for(int i = 1; i < N; i++){
int f;
std::cin >> f;
--f;
adj[f].push_back(i);
}
std::vector<int> deep(N), sz(N);
std::function<void(int, int)> dfs = [&](int u, int f){
deep[u] = u == 0 ? 0 : deep[f] + 1;
sz[u] = 1;
for(int v : adj[u]){
dfs(v, u);
sz[u] += sz[v];
}
};
dfs(0, -1);
std::vector<int> id(N);
for(int i = 0; i < N; i++){
id[i] = i;
}
auto val = [&](int i){
return -deep[i] + sz[i] - v[i];
};
std::sort(all(id), [&](int i, int j){
return val(i) > val(j);
});
std::vector<int> a(N);
for(int i = 1; i < N; i += 2){
a[id[i]] = 1;
}
i64 ans = 0;
for(int i = 0; i < N; i++){
// std::cerr << id[i] + 1 << "\n";
// std::cerr << val(i) << "\n";
if(a[i] == 0) ans -= v[i];
// else ans += v[i];
}
// std::cerr << ans << "\n";
std::vector<int> pre(N);
std::function<void(int, int)> dfs1 = [&](int u, int f){
if(u != 0){
// std::cerr << u + 1 << " ";
if(a[u] == 0){
ans -= pre[f];
// std::cerr << -pre[f] << "\n";
} else{
ans += deep[u] - pre[f];
// std::cerr << deep[u] - pre[f] << "\n";
}
pre[u] = pre[f];
}
pre[u] += a[u];
for(int v : adj[u]){
dfs1(v, u);
}
};
dfs1(0, -1);
std::cout << ans << "\n";
}
int main(){
std::cin.tie(0);
std::ios::sync_with_stdio(0);
int T = 1;
// std::cin >> T;
for(int i = 0; i < T; i++){
solve();
}
return 0;
}
/*
来日纵使千千阕歌,飘于远方我路上
来日纵使千千晚星,亮过今晚月亮
都比不起这宵美丽,亦绝不可使我更欣赏
Ah 因你今晚共我唱
*/
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 3616kb
input:
8 0 1 1 0 0 0 0 0 3 1 8 4 1 3 1
output:
3
result:
ok single line: '3'
Test #2:
score: 0
Accepted
time: 0ms
memory: 3812kb
input:
10 1 0 0 0 0 0 0 0 0 1 8 1 9 10 9 8 4 5 1
output:
2
result:
ok single line: '2'
Test #3:
score: 0
Accepted
time: 0ms
memory: 3588kb
input:
8 1 0 1 0 0 1 0 0 1 6 2 1 2 1 5
output:
2
result:
ok single line: '2'
Test #4:
score: 0
Accepted
time: 0ms
memory: 3560kb
input:
8 0 0 0 1 1 0 1 1 7 1 3 4 1 4 3
output:
0
result:
ok single line: '0'
Test #5:
score: 0
Accepted
time: 0ms
memory: 3620kb
input:
10 0 0 1 0 0 0 0 1 1 0 1 5 1 1 9 1 2 4 4
output:
3
result:
ok single line: '3'
Test #6:
score: 0
Accepted
time: 56ms
memory: 15784kb
input:
199998 2 2 3 2 1 3 0 2 0 3 2 0 2 2 1 1 3 3 3 3 2 0 1 2 0 3 1 1 0 0 3 3 3 3 0 3 2 2 1 1 2 2 0 3 3 3 1 2 0 2 2 1 2 0 3 2 0 0 0 3 2 3 0 1 1 2 0 2 2 0 3 1 1 2 3 1 0 3 0 2 1 0 3 3 1 1 2 3 1 0 3 0 1 2 3 1 3 3 0 3 1 2 1 1 3 2 1 3 3 3 1 1 2 3 2 0 2 3 2 2 1 1 2 1 2 0 1 0 1 3 3 2 3 2 0 3 2 2 2 0 3 2 1 2 3 1 2...
output:
-101057
result:
ok single line: '-101057'
Test #7:
score: 0
Accepted
time: 68ms
memory: 15656kb
input:
199992 2 2 0 0 2 0 1 2 1 2 2 1 1 2 1 1 3 0 0 3 1 0 2 0 0 1 0 3 2 0 2 3 2 3 2 0 3 2 2 2 3 2 1 3 1 1 2 3 1 2 0 0 2 2 0 3 1 1 0 1 1 1 0 2 3 0 3 0 3 1 3 2 3 1 0 3 2 2 3 1 3 0 2 2 0 3 2 2 1 1 0 1 2 0 1 3 1 2 1 1 3 3 1 2 1 3 0 1 1 1 2 1 2 0 2 0 0 0 2 0 0 3 1 3 0 1 1 0 3 1 1 2 3 1 1 0 2 0 3 2 1 2 0 2 1 0 0...
output:
-63508
result:
ok single line: '-63508'
Test #8:
score: 0
Accepted
time: 58ms
memory: 15836kb
input:
199993 2 3 0 1 3 3 2 1 0 2 2 0 3 1 2 2 1 2 2 3 0 1 0 0 2 1 1 3 2 1 0 2 1 2 2 3 3 3 1 2 2 2 1 3 2 2 0 2 3 3 2 1 3 0 1 3 3 2 1 1 3 0 2 2 0 3 1 3 2 0 1 1 3 0 0 2 3 2 1 0 1 1 3 0 1 0 2 3 2 1 0 3 2 2 3 1 3 2 2 0 1 2 2 0 2 1 2 0 1 1 1 2 2 3 2 1 2 2 0 0 2 3 3 1 1 0 3 2 2 3 1 3 2 1 3 0 2 3 0 3 0 3 3 2 1 2 2...
output:
-72819
result:
ok single line: '-72819'
Test #9:
score: 0
Accepted
time: 60ms
memory: 15848kb
input:
200000 0 2 2 2 2 3 2 1 2 3 3 1 2 1 0 1 2 1 2 3 1 2 2 3 3 3 2 2 0 3 3 0 0 1 3 3 0 1 0 1 0 0 2 0 1 3 1 0 1 2 1 1 1 2 1 3 3 3 2 2 1 2 0 2 1 0 3 2 1 0 0 3 1 3 1 0 2 0 1 3 2 1 3 3 2 3 3 1 3 2 2 0 0 1 2 0 3 3 1 0 3 2 1 3 1 3 0 0 2 3 1 2 3 0 0 0 2 3 1 0 1 1 3 2 2 6 3 2 2 0 2 1 0 2 3 0 0 0 1 2 3 1 1 1 2 2 3...
output:
-87803
result:
ok single line: '-87803'
Test #10:
score: 0
Accepted
time: 76ms
memory: 15812kb
input:
199994 69536 93956 146435 58370 55904 55731 40099 34869 22948 62455 25557 61814 118354 34694 37607 102825 86029 141405 6587 18273 174985 101354 139220 168750 14953 92256 162412 164115 172096 52676 126381 152299 140824 180431 131743 128463 115582 173595 160676 168294 26378 66194 115896 193154 79199 4...
output:
-10000211244
result:
ok single line: '-10000211244'
Test #11:
score: 0
Accepted
time: 0ms
memory: 3628kb
input:
31 0 2 0 1 0 1 2 2 0 1 2 0 2 2 1 2 1 0 0 0 2 1 2 0 1 0 0 2 0 1 0 15 2 13 15 8 30 15 25 25 2 13 1 13 1 30 1 2 30 11 2 13 13 11 13 1 15 12 16 15 15
output:
-6
result:
ok single line: '-6'
Test #12:
score: 0
Accepted
time: 19ms
memory: 13716kb
input:
199992 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0...
output:
20452
result:
ok single line: '20452'
Test #13:
score: 0
Accepted
time: 28ms
memory: 13856kb
input:
199996 0 0 1 0 0 1 0 1 1 0 1 1 1 1 1 1 1 1 0 1 1 0 1 1 1 1 0 0 0 1 0 1 1 1 0 1 0 0 1 0 0 1 0 0 0 0 0 1 1 0 0 0 1 1 1 0 0 1 1 0 0 0 0 0 0 1 1 1 1 1 1 1 0 0 1 1 1 1 1 1 1 1 0 1 1 1 0 0 0 1 1 0 1 1 0 1 1 1 0 0 1 0 0 1 0 1 1 1 1 0 0 0 0 1 1 1 1 1 1 0 0 0 1 0 0 0 0 1 1 1 1 1 1 0 1 1 0 1 0 1 0 1 1 1 0 0 0...
output:
20009
result:
ok single line: '20009'
Test #14:
score: 0
Accepted
time: 24ms
memory: 13736kb
input:
199996 3 1 1 0 3 0 1 3 0 3 1 3 1 0 2 0 3 3 1 2 0 3 3 0 2 2 0 2 3 1 3 0 0 3 1 0 0 1 2 1 3 2 3 0 2 1 2 0 1 0 3 1 3 2 0 1 1 3 3 1 2 2 3 2 1 0 3 0 3 0 0 2 3 3 2 0 0 1 2 1 3 3 0 0 1 2 2 0 1 1 3 3 1 3 1 0 1 0 0 0 1 0 1 2 1 0 1 2 2 0 2 3 0 1 3 2 1 0 3 3 3 3 0 3 0 3 0 3 1 2 0 3 1 2 3 2 0 1 2 1 1 3 2 1 0 1 1...
output:
-100430
result:
ok single line: '-100430'
Test #15:
score: 0
Accepted
time: 48ms
memory: 13816kb
input:
199999 129505 14159 194788 69896 53179 103846 110185 158026 53493 4149 158821 181222 159742 175140 155608 37494 112878 78442 152990 5490 101005 39752 164304 162429 83386 88164 31144 84029 173037 92918 2500 103066 137572 20077 50183 115122 158847 51492 130020 193352 195330 30765 183180 118688 125622 ...
output:
-10014348789
result:
ok single line: '-10014348789'
Test #16:
score: 0
Accepted
time: 0ms
memory: 3776kb
input:
21 0 0 0 2 1 1 0 2 2 2 2 0 0 1 2 2 1 0 0 2 1 17 9 3 4 1 11 15 19 4 8 10 11 7 6 6 14 2 2 12 20
output:
-12
result:
ok single line: '-12'
Test #17:
score: 0
Accepted
time: 100ms
memory: 32548kb
input:
199995 18 17 17 5 17 15 14 20 7 18 10 15 18 15 15 7 18 13 16 11 5 14 9 9 18 20 5 9 15 15 3 12 4 20 10 1 9 3 1 0 12 1 16 17 19 8 16 17 19 8 11 19 12 10 13 6 4 4 9 19 17 14 6 0 18 2 15 9 7 0 4 17 20 14 10 6 7 0 5 11 2 7 16 5 14 12 2 11 7 17 5 1 0 17 14 20 19 16 2 19 2 16 5 6 2 4 13 6 5 4 12 13 11 7 5 ...
output:
-3519230
result:
ok single line: '-3519230'
Test #18:
score: 0
Accepted
time: 93ms
memory: 32532kb
input:
199991 17 4 13 20 14 9 9 6 5 2 20 4 5 10 5 2 8 3 16 8 2 0 18 20 19 16 10 13 19 9 12 19 11 13 14 6 11 16 20 12 5 11 16 14 19 18 3 0 13 6 1 14 13 14 14 8 13 15 3 3 5 11 9 10 15 6 6 4 16 19 17 18 15 9 6 14 12 20 15 6 19 6 15 11 1 9 16 4 8 0 4 2 13 16 5 15 12 14 20 12 20 11 15 18 7 6 17 4 20 11 8 4 6 9 ...
output:
-3391196
result:
ok single line: '-3391196'
Test #19:
score: 0
Accepted
time: 85ms
memory: 32468kb
input:
199990 8 20 5 15 1 2 9 1 14 1 10 13 0 20 18 10 3 12 13 19 1 7 2 3 12 5 2 12 13 8 16 3 4 4 17 19 9 10 14 20 5 6 13 12 4 20 19 9 10 5 9 9 2 17 17 2 10 2 2 12 20 14 11 2 1 16 15 0 2 5 1 20 11 19 5 20 16 14 9 14 5 13 17 19 3 13 8 7 13 4 15 12 16 19 18 19 3 15 4 14 5 15 14 3 19 5 13 5 15 6 17 3 10 14 1 6...
output:
-3235337
result:
ok single line: '-3235337'
Test #20:
score: 0
Accepted
time: 111ms
memory: 32628kb
input:
199997 18 18 7 20 11 13 2 3 3 15 16 13 15 17 16 5 3 9 16 18 13 7 17 5 11 0 9 14 11 5 19 4 19 12 6 15 17 18 4 13 15 1 16 16 16 18 7 0 1 17 5 3 1 13 1 12 12 0 1 20 9 17 13 0 3 9 7 0 9 9 6 1 0 5 18 9 15 1 3 0 11 3 12 20 10 7 17 1 4 11 6 12 6 4 17 5 5 12 1 12 3 2 16 11 13 13 13 18 2 1 17 0 11 11 19 11 1...
output:
-3568351
result:
ok single line: '-3568351'
Test #21:
score: 0
Accepted
time: 0ms
memory: 3556kb
input:
7 0 0 1 0 0 0 0 1 1 2 2 3 3
output:
2
result:
ok single line: '2'