Cod sursa(job #2369962)

Utilizator usureluflorianUsurelu Florian-Robert usureluflorian Data 6 martie 2019 10:00:20
Problema Infasuratoare convexa Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.05 kb
#include <bits/stdc++.h>
using namespace std;
ifstream f ("infasuratoare.in");
ofstream g ("infasuratoare.out");
const int nmax=12e4+3;
int n,sol[nmax],k;
struct usu
{
    long double x,y;
}v[nmax];
long double det(usu &t1,usu &t2,usu &t3)
{
    return t1.x*t2.y+t2.x*t3.y+t3.x*t1.y-t2.y*t3.x-t3.y*t1.x-t1.y*t2.x;
}
bool inline cmp(usu &t1,usu &t2)
{
    return det(t1,t2,v[1])<0;
}
int main()
{
    ios::sync_with_stdio(false);
    f>>n;
    f>>v[1].x>>v[1].y;
    for(int i=2;i<=n;++i)
    {
        f>>v[i].x>>v[i].y;
        if(v[i].x<v[1].x)
        {
            swap(v[1],v[i]);
            continue;
        }
        if(v[i].x==v[1].x&&v[i].y<v[1].y)
        {
            swap(v[1],v[i]);
            continue;
        }
    }
    sort(v+2,v+n+1,cmp);
    k=0;
    sol[++k]=1;
    for(int i=2;i<=n;++i)
    {
        while(k>=2&&det(v[sol[k-1]],v[sol[k]],v[i])>0) --k;
        sol[++k]=i;
    }
    g<<k<<'\n';
    for(int i=k;i>=1;--i) g<<fixed<<setprecision(6)<<v[sol[i]].x<<' '<<v[sol[i]].y<<'\n';
    return 0;
}