# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
961940 | IUA_Hasin | 친구 (IOI14_friend) | C++17 | 20 ms | 3676 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "friend.h"
#include <bits/stdc++.h>
#define endl "\n"
#define yeap cout<<"YES"<<endl
#define nope cout<<"NO"<<endl
#define ll long long
using namespace std;
const ll M = 1e5;
vector<vector<ll>> subsets;
vector<ll> subset;
ll arr[M];
const ll N = 1e4;
vector<ll> v[N];
ll deg[N];
ll vis[N];
void subs(ll i, ll n){
if(i==n){
subsets.push_back(subset);
return;
} else {
subs(i+1, n);
subset.push_back(i+1);
subs(i+1, n);
subset.pop_back();
return;
}
}
// Find out best sample
int findSample(int n,int confidence[],int host[],int protocol[]){
if(n<=10){
subs(-1, n-1);
ll status = 1;
// for(ll i=0; i<subsets.size(); i++){
// for(ll j=0; j<subsets[i].size(); j++){
// cout << subsets[i][j] << " ";
// }
// cout<<endl;
// }
for(int i=1; i<n; i++){
ll a = host[i];
ll b = protocol[i];
if(b==0){
v[i].push_back(a);
v[a].push_back(i);
} else if(b==1){
for(int j=0; j<v[a].size(); j++){
ll c = v[a][j];
v[i].push_back(c);
v[c].push_back(i);
}
} else {
for(int j=0; j<v[a].size(); j++){
ll c = v[a][j];
v[i].push_back(c);
v[c].push_back(i);
}
v[i].push_back(a);
v[a].push_back(i);
}
}
ll stat[n+1][n+1];
for(int i=0; i<n+1; i++){
for(int j=0; j<n+1; j++){
stat[i][j] = 0;
}
}
for(int i=0; i<n; i++){
for(int j=0; j<v[i].size(); j++){
ll a = v[i][j];
stat[i][a] = 1;
}
}
// for(int i=0; i<n+1; i++){
// for(int j=0; j<n+1; j++){
// cout << stat[i][j] << " ";
// }
// cout<<endl;
// }
ll ans = 0;
for(int i=0; i<subsets.size(); i++){
status = 1;
ll a = subsets[i].size();
for(int j=0; j<a; j++){
for(int k=j+1; k<a; k++){
ll b = subsets[i][j];
ll c = subsets[i][k];
if(stat[b][c]==1){
status = -1;
}
}
}
// cout << status << endl;
if(status==1){
ll temp = 0;
for(int j=0; j<a; j++){
ll b = subsets[i][j];
ll c = confidence[b];
temp = temp+c;
}
ans = max(temp, ans);
}
}
return ans;
} else if(protocol[1]==1){
ll ans = 0;
for(int i=0; i<n; i++){
ans = ans+confidence[i];
}
return ans;
} else if(protocol[1]==2){
int ans = -1;
for(int i=0; i<n; i++){
ans = max(ans, confidence[i]);
}
return ans;
}
}
컴파일 시 표준 에러 (stderr) 메시지
# | 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... |