Submission #1148051

#TimeUsernameProblemLanguageResultExecution timeMemory
1148051aarb_.tomatexd친구 (IOI14_friend)C++20
35 / 100
1 ms584 KiB
#include "friend.h" #include <bits/stdc++.h> using namespace std; vector<vector<int>>v,dp; vector<int>a; int ans=0; void dfs(int x,int p){ dp[x][1]=a[x]; for(int z:v[x]){ if(z!=p){ dfs(z,x); dp[x][0]+=max(dp[z][1],dp[z][0]); dp[x][1]+=dp[z][0]; } } } int sub4(int n,int confidence[],int host[]){ v.resize(n); a.resize(n); dp.assign(n,vector<int>(2,0)); for(int i=0;i<n;i++) a[i]=confidence[i]; for(int i=1;i<n;i++){ v[i].push_back(host[i]); v[host[i]].push_back(i); } dfs(0,0); return max(dp[0][0],dp[0][1]); } int findSample(int n,int confidence[],int host[],int protocol[]){ if(protocol[1]==0) return sub4(n,confidence,host); for(int i=0;i<n;i++) ans=(protocol[1]&1 ? ans+confidence[i] : max(ans,confidence[i])); return ans; }
#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...