이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#ifdef NYAOWO
#include "grader.cpp"
#endif
#include "friend.h"
#include <bits/stdc++.h>
#define For(i, a, b) for(int i = a; i <= b; i++)
#define Forr(i, a, b) for(int i = a; i >= b; i--)
using namespace std;
const int MAXN = 100010;
int dp0[MAXN + 10];
int dp1[MAXN + 10];
inline void chmax(int &a, const int &b) {
if(a < b) a = b;
}
// Find out best sample
int findSample(int n,int val[],int par[],int op[]){
For(i, 0, n - 1) {
dp0[i] = 0;
dp1[i] = val[i];
}
Forr(i, n - 1, 1) {
int p = par[i];
if(op[i] == 0) {
dp1[p] += dp0[i];
dp0[p] += max(dp0[i], dp1[i]);
} else if(op[i] == 2) {
dp1[p] = max(dp1[p] + dp0[i], dp0[p] + dp1[i]);
dp0[p] += dp0[i];
} else if(op[i] == 1) {
dp1[p] = max(dp1[p] + max(dp0[i], dp1[i]), dp0[p] + dp1[i]);
dp0[p] += dp0[i];
}
}
return max(dp0[0], dp1[0]);
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |