Cod sursa(job #1597559)

Utilizator AeroHHorea Stefan AeroH Data 12 februarie 2016 02:49:27
Problema Infasuratoare convexa Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.57 kb
#include <bits/stdc++.h>
#define x first
#define y second
#define N 240001
#define p pair<double,double>
using namespace std;
string a="infasuratoare.";
ifstream f(a+"in");
ofstream g(a+"out");

int i,j,M,t;
p v[N],h[N];

bool d(p &a,p &b,p &c)
{
return (a.x-c.x)*(b.y-c.y)-(a.y-c.y)*(b.x-c.x)<0;
}

int main()
{
f>>M;
for(i=0;i<M;++i)f>>v[i].x>>v[i].y;
sort(v,v+M);reverse_copy(v,v+M-1,v+M);
for(i=0;i<2*M-1;h[j++]=v[i++])
while(j>1&&d(h[j-2],h[j-1],v[i]))--j;
g<<--j;
for(i=0;i<j;++i)g<<fixed<<setprecision(9)<<'\n'<<h[i].x<<" "<<h[i].y;
return 0;
}