# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
374557 | idk321 | 친구 (IOI14_friend) | C++11 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "friend.h"
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1005;
vector<int> adj[N];
// Find out best sample
int dp[N][2];
int* conf;
int n;
bool open[N];
int dfs(int node, int par)
{
dp[node][0] = 0;
dp[node][1] = conf[node];
for (int next : adj[node])
{
if (next == par) continue;
dfs(next, node);
dp[node][0] += max(dp[next][0], dp[next][1]);
dp[node][1] += dp[next][0];
}
return max(dp[node][0], dp[node][1]);
}
bool legal(int node)
{
for (int next : adj[node])
{
if (open[next]) return false;
}
return true;
}
int go(int i, int sum)
{
if (i == n)
{
bool ok = true;
for (int j = 0; j< n; j++) if (open[j])ok = ok && legal(j);
if (ok) return sum;
return 0;
}
int best = 0;
best = max(best, go(i + 1, sum));
open[i] = true;
best = max(best, go(i + 1, sum + conf[i]));
open[i] = false;
return best;
}
int compCol[N];
int comp[N];
int compSz[N];
void colour(int node, int cur, int ccomp)
{
compCol[ccomp] += cur;
comp[node] = ccomp;
compSz[ccomp]++;
for (int next : adj[node])
{
if (comp[next] != -1) continue;
colour(next, !cur);
}
}
int findSample(int n1,int conf1[],int host[],int pro[]){
n = n1;
conf = conf1;
int ans=10;
for (int i = 1; i < n; i++)
{
if (pro[i] == 0)
{
adj[i].push_back(host[i]);
adj[host[i]].push_back(i);
} else if (pro[i] == 1)
{
for (int j : adj[host[i]])
{
adj[i].push_back(j);
adj[j].push_back(i);
}
} else
{
for (int j : adj[host[i]])
{
adj[i].push_back(j);
adj[j].push_back(i);
}
adj[i].push_back(host[i]);
adj[host[i]].push_back(i);
}
}
int freq[3] = {};
for (int i = 1; i < n; i++) freq[pro[i]]++;
if (freq[0] == 0 && freq[2] == 0)
{
int sum = 0;
for (int i = 0; i < n; i++) sum += conf[i];
return sum;
} else if (freq[0] == 0 && freq[1] == 0)
{
int res = 0;
for (int i = 0; i < n; i++) res = max(res, conf[i]);
return res;
} else if (freq[1] == 0 && freq[2] == 0)
{
return dfs(0, -1);
} else if (n <= 10)
{
return go(0, 0);
} else
{
int res = 0;
for (int i = 0; i< n; i++) comp[i] = -1;
int ccomp = 0;
for (int i = 0; i < n; i++)
{
if (comp[i] == -1)
{
colour(i, 1, ccomp);
ccomp++;
}
}
for (int i = 0; i < ccomp; i++)
{
res += max(compCol[i], compSz[i] - compCol[i]);
}
return res;
}
return ans;
}