Cod sursa(job #1901597)

Utilizator stefantagaTaga Stefan stefantaga Data 4 martie 2017 09:48:55
Problema Reuniune Scor 20
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.97 kb
#include <fstream>

using namespace std;
ifstream f("reuniune.in");
ofstream g("reuniune.out");
struct dreptunghi
{
    long long a,b,c,d;
}h,v,t,ok,o,p,q;
void intersectie(dreptunghi k,dreptunghi r,dreptunghi &h)
{
    h.a=max(k.a,r.a);
    h.b=max(k.b,r.b);
    h.c=min(k.c,r.c);
    h.d=min(k.d,r.d);
    if (h.a>h.c||h.b>h.d)
    {
        h.a=0;
        h.c=0;
        h.b=0;
        h.d=0;
    }
}
int arie (dreptunghi u)
{
    return ((u.d-u.b)*(u.c-u.a));
}
int perimetru (dreptunghi u)
{
    return (((u.d-u.b)+(u.c-u.a))*2);
}
int z,k,sa,sp;
int main()
{
    f>>v.a>>v.b>>v.c>>v.d>>t.a>>t.b>>t.c>>t.d>>ok.a>>ok.b>>ok.c>>ok.d;
    intersectie (v,ok,h);
    intersectie (v,t,o);
    intersectie (ok,t,p);
    intersectie (h,t,q);
    sa=arie(v)+arie(t)+arie(ok)-arie(h)-arie(o)-arie(p)+arie(q);
    sp=perimetru(v)+perimetru(t)+perimetru(ok)-perimetru(h)-perimetru(o)-perimetru(p)+perimetru(q);
    g<<sa<<" "<<sp<<'\n';
    return 0;
}