Pagini recente » Cod sursa (job #1127591) | Cod sursa (job #2879852) | Cod sursa (job #480144) | Cod sursa (job #1119091) | Cod sursa (job #891056)
Cod sursa(job #891056)
Utilizator |
Simoiu Robert SpiderMan |
Data |
25 februarie 2013 13:22:44 |
Problema |
Aria |
Scor |
Ascuns |
Compilator |
cpp |
Status |
done |
Runda |
|
Marime |
0.82 kb |
# include <cstdio>
# include <cmath>
# include <fstream>
# include <iomanip>
using namespace std;
const char *FIN = "aria.in", *FOU = "aria.out";
const int MAX = 300005;
struct punct {
double x, y;
} vec[MAX];
int N;
inline long double arie (punct *vec, int sz) {
long double sol = 0;
vec[sz++] = vec[0]; // vec[N] = vec[0]
for (int i = 0; i + 1 < sz; ++i)
sol += (long double) (vec[i].x * vec[i + 1].y - vec[i + 1].x * vec[i].y);
return fabs (sol * 0.5);
}
int main (void) {
freopen (FIN, "r", stdin);
ofstream g(FOU);
//freopen (FOU, "w", stdout);
scanf ("%d", &N);
for (int i = 0; i < N; ++i)
scanf ("%lf %lf", &vec[i].x, &vec[i].y);
g << setprecision(6) << fixed;
g << arie (vec, N) << "\n";
//printf ("%Lf", arie (vec, N));
}