Cod sursa(job #3217374)

Utilizator GILIEDAVIDGilie David Florin GILIEDAVID Data 22 martie 2024 16:56:22
Problema Infasuratoare convexa Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.84 kb
#include <bits/stdc++.h>

using namespace std;
ifstream f("infasuratoare.in");
ofstream g("infasuratoare.out");
struct bln
{
    double x,y;
}v[120005];
int n,mn,i;
double det(bln a,bln b,bln c)
{
    return a.x*b.y+b.x*c.y+c.x*a.y-a.x*c.y-b.x*a.y-c.x*b.y;
}
bool comp(bln a,bln b)
{
    return (det(v[1],a,b)>0);
}
int main()
{
    f>>n;
    f>>v[1].x>>v[1].y;
    mn=1;
    for(i=2;i<=n;i++)
    {
        f>>v[i].x>>v[i].y;
        if(v[i].x<v[mn].x|| (v[i].x==v[mn].x && v[i].y<v[mn].y))
            mn=i;
    }
    swap(v[1],v[mn]);
    sort(v+2,v+n+1,comp);
    int k=2;
    v[n+1]=v[1];
    for(i=3;i<=n+1;i++)
    {
        while(k>=2 && det(v[k-1],v[k],v[i])<0) k--;
        v[++k]=v[i];
    }
    g<<k-1<<'\n';
    for(i=2;i<=k;i++)
        g<<fixed<<setprecision(6)<<v[i].x<<" "<<v[i].y<<'\n';
    return 0;
}