Cod sursa(job #1500820)

Utilizator DanielRusuDaniel Rusu DanielRusu Data 12 octombrie 2015 18:45:04
Problema Aria Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.88 kb

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# include <cassert>
# include <cstdio>
# include <cmath>

const char *FIN = "aria.in", *FOU = "aria.out";
const int MAX = 100005;

struct punct {
    double x, y;
} vec[MAX];

int N;
double sol;

int main (void) {
    assert (freopen (FIN, "r", stdin));
    assert (freopen (FOU, "w", stdout));

    assert (scanf ("%d", &N) == 1);
    assert (1 <= N && N <= 100000);
    for (int i = 0; i < N; ++i) {
        assert (scanf ("%lf %lf", &vec[i].x, &vec[i].y) == 2);
        assert (-10000000 <= vec[i].x && vec[i].x <= 10000000);
        assert (-10000000 <= vec[i].y && vec[i].y <= 10000000);
    }
    vec[N] = vec[0];
    for (int i = 0; i < N; ++i)
        sol += (vec[i].x * vec[i + 1].y - vec[i + 1].x * vec[i].y);
    printf ("%lf", fabs (sol / 2.0));