Submission #544380

#TimeUsernameProblemLanguageResultExecution timeMemory
544380sliviuFriend (IOI14_friend)C++17
100 / 100
25 ms3396 KiB
#include <bits/stdc++.h> using namespace std; int findSample(int n, int confidence[], int host[], int protocol[]) { vector<pair<int, int>> dp(n); for (int i = 0; i < n; ++i) dp[i].first = confidence[i]; for (int i = n - 1; i; --i) { int cur = host[i], last = i; if (protocol[i] == 0) dp[cur] = {dp[cur].first + dp[last].second,dp[cur].second + max(dp[last].first,dp[last].second)}; else if (protocol[i] == 1) dp[cur] = {max(dp[cur].first + max(dp[last].first,dp[last].second),dp[cur].second + dp[last].first),dp[cur].second + dp[last].second}; else dp[cur] = {max(dp[cur].first + dp[last].second,dp[cur].second + dp[last].first),dp[cur].second + dp[last].second}; } return max(dp[0].first, dp[0].second); }
#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...