Pagini recente » Cod sursa (job #886933) | Cod sursa (job #1714586) | Cod sursa (job #2168124) | Cod sursa (job #966375) | Cod sursa (job #1683978)
#include <fstream>
#include <cstdio>
#include <cmath>
#include <iomanip>
#include <iostream>
using namespace std;
//ofstream g("aria.out");
FILE *f, *g;
double aria;
double modul(double a)
{
if(a < 0)
return -a;
return a;
}
int n, i ;
double x[100003], y[100003];
int main()
{
f = fopen("aria.in", "r");
g = fopen("aria.out", "w");
fscanf(f, "%d", &n);
for(i = 1 ;i <= n; i ++)
{
fscanf(f, "%lf%lf", &x[i], &y[i]);
//cout << x[i] << " " << y[i] << '\n';
}
x[n + 1] = x[1];
y[n + 1] = y[1];
for(i = 1; i <= n ; i ++)
{
aria += ( (((x[i] * y[i + 1]) - (x[i + 1] * y[i ]))));
// printf("%f %f %f %f\n", x[i] , x[i + 1] , y[i] , y[i + 1]);
}
// 1/2*modul((x1-x2)*(y1+y2) + (x2-x3)*(y2+y3) + ... + (x(n-1)-xn)*(y(n-1)+yn) + (xn-x1)*(yn+y1))
fprintf(g, "%lf", aria / 2.0D);
fclose(f);
fclose(g);
return 0;
}