Pagini recente » Cod sursa (job #2267184) | Cod sursa (job #1430196) | Cod sursa (job #3331950) | What you gonna do when they come for you? | Cod sursa (job #3309353)
#include <bits/stdc++.h>
using namespace std;
double determinant(pair <double, double> A, pair <double, double> B, pair <double, double> C) {
return A.first * B.second + B.first * C.second + C.first * A.second -
A.second * B.first - B.second * C.first - C.second * A.first;
}
double getSegmentArea(pair <double, double> A, pair <double, double> B) {
return determinant({0, 0}, A, B);
}
pair <double, double> v[100005];
int32_t main() {
freopen("aria.in", "r", stdin);
freopen("aria.out", "w", stdout);
int n;
cin >> n;
for (int i = 1; i <= n; i++) {
cin >> v[i].first >> v[i].second;
}
v[n + 1] = v[1];
double aria = 0;
for (int i = 1; i <= n; ++i) {
aria += getSegmentArea(v[i], v[i + 1]);
}
double result = aria / 2.0;
cout << fixed << setprecision(6) << result;
}