이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "trilib.h"
//#include "trilib.c"
using namespace std;
map<vector<int>,bool> f;
set<int> border;
bool good(int a,int b,int c)
{
vector<int> v;
v.push_back(a);
v.push_back(b);
v.push_back(c);
sort(v.begin(),v.end());
if(f.count(v)==0)
f[v]=is_clockwise(v[0],v[1],v[2]);
bool ans=f[v];
int nr=0;
if(a!=v[0])
nr++;
if(b!=v[1])
nr++;
if(c!=v[2])
nr++;
if(nr%2==0&&nr>0)
ans=!ans;
return ans;
}
int main()
{
int n;
n=get_n();
for(int i=1;i<=n;i++)
for(int j=i+1;j<=n;j++)
if(border.find(i)==border.end()||border.find(j)==border.end())
{
int val=-1;
bool ok=1;
for(int k=1;k<=n;k++)
if(k!=i&&k!=j)
{
int x=good(i,j,k);
if(val==-1)
val=x;
else if(val!=x)
{
ok=0;
break;
}
}
if(ok)
{
border.insert(i);
border.insert(j);
}
}
int ans=border.size();
give_answer(ans);
return 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... |