Submission #1081566

#TimeUTC-0UsernameProblemLanguageResultExecution timeMemory
10815662024-08-30 07:30:34vjudge1Mag (COCI16_mag)C++17
84 / 120
893 ms262144 KiB
#include<bits/stdc++.h>
using namespace std;
bool operator < (const pair<int, int>& x, const pair<int, int>& y) {
return 1LL * x.first * y.second < 1LL * x.second * y.first;
}
int main() {
int n; cin >> n;
vector<vector<int>> adj(n + 1, vector<int>());
for (int i = 1, a, b; i < n; i++) {
cin >> a >> b;
adj[a].push_back(b);
adj[b].push_back(a);
}
vector<int> val(n + 1, 0);
vector<vector<int>> dp(n + 1, vector<int>()), dp_pref(n + 1, vector<int>()), dp_suf(n + 1, vector<int>());
vector<int> dp2(n + 1, 0);
for (int i = 1; i <= n; i++) cin >> val[i];
function<void(int, int)> dfs1 = [&](int u, int par) -> void {
if (u != 1 && adj[u].size() == 1) {
dp[u].emplace_back(0);
dp_pref[u].emplace_back(0);
dp_suf[u].emplace_back(0);
return;
}
for (int v: adj[u]) {
if (v == par) { dp[u].push_back(0); continue; }
dfs1(v, u);
if (val[v] != 1) dp[u].push_back(0);
 
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...