Submission #1148051

#TimeUsernameProblemLanguageResultExecution timeMemory
1148051aarb_.tomatexdFriend (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...