Cod sursa(job #2359089)

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