제출 #1015400

#제출 시각아이디문제언어결과실행 시간메모리
1015400parsadox2친구 (IOI14_friend)C++17
8 / 100
1 ms4700 KiB
#include "friend.h" #include <bits/stdc++.h> using namespace std; const int N = 1e5 + 10; int n , ar[N] , dp[N][2]; bool par[N] , prv[N]; vector <int> adj[N]; void Dfs(int v) { for(auto u : adj[v]) Dfs(u); if(adj[v].empty()) { dp[v][1] = ar[v]; //cout << v << " : " << dp[v][0] << " " << dp[v][1] << endl; return; } int tmp[2]; tmp[0] = tmp[1] = 0; for(auto u : adj[v]) { if(prv[u]) tmp[1] = max(tmp[1] + dp[u][0] , tmp[0] + dp[u][1]); else tmp[1] += dp[u][1]; tmp[0] += dp[u][0]; } dp[v][0] = tmp[1]; tmp[0] = tmp[1] = ar[v]; for(auto u : adj[v]) { if(par[u]) tmp[1] += dp[u][0]; else if(prv[u]) tmp[1] = max(tmp[1] + dp[u][0] , tmp[0] + dp[u][1]); else tmp[1] += dp[u][1]; tmp[0] += dp[u][0]; } dp[v][1] = max(dp[v][0] , tmp[1]); //cout << v << " : " << dp[v][0] << " " << dp[v][1] << endl; } int findSample(int nn,int confidence[],int host[],int protocol[]){ n = nn; for(int i = 0 ; i < n ; i++) ar[i] = confidence[i]; int ans = 0; for(int i = 0 ; i < n ; i++) ans += ar[i]; return ans; for(int i = 1 ; i < n ; i++) { adj[host[i]].push_back(i); if(protocol[i] == 0) par[i] = true; else if(protocol[i] == 1) prv[i] = true; else { par[i] = true; prv[i] = true; } } Dfs(0); return dp[0][1]; }
#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...