平面上有N个点. 求出所有以这N个点为顶点的三角形的面积和 N<=3000
标签:计算几何 oss 代码 排序 name include 极角 bool class
BZOJ_1132_[POI2008]Tro_计算几何
平面上有N个点. 求出所有以这N个点为顶点的三角形的面积和 N<=3000
第一行给出数字N,N在[3,3000] 下面N行给出N个点的坐标,其值在[0,10000]
保留一位小数,误差不超过0.1
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
typedef long long f2;
#define eps 1e-7
#define N 3050
struct Point {
f2 x,y;
Point() {}
Point(f2 x_,f2 y_) :
x(x_),y(y_) {}
Point operator + (const Point &p) const {return Point(x+p.x,y+p.y);}
Point operator - (const Point &p) const {return Point(x-p.x,y-p.y);}
bool operator < (const Point &p) const {
if(y==p.y) return x<p.x; return y<p.y;
}
}a[N],t[N];
typedef Point Vector;
int n;
f2 sx[N],sy[N];
f2 cross(const Point &p1,const Point &p2) {return p1.x*p2.y-p1.y*p2.x;}
bool cmp(const Vector &x,const Vector &y) {
return cross(x,y)>eps;
}
int main() {
scanf("%d",&n);
int i,j;
for(i=1;i<=n;i++) {
scanf("%lld%lld",&a[i].x,&a[i].y);
}
sort(a+1,a+n+1);
f2 ans=0;
for(i=1;i<=n-2;i++) {
for(j=i+1;j<=n;j++) t[j]=a[j]-a[i];
sort(t+i+1,t+n+1,cmp);
sx[i]=sy[i]=0;
for(j=i+1;j<=n;j++) {
sx[j]=sx[j-1]+t[j].x;
sy[j]=sy[j-1]+t[j].y;
}
for(j=i+1;j<=n;j++) {
ans+=(t[j].x*(sy[n]-sy[j])-t[j].y*(sx[n]-sx[j]));
}
}
printf("%lld.%lld\n",ans/2,ans%2*5);
}
标签:计算几何 oss 代码 排序 name include 极角 bool class
原文地址:https://www.cnblogs.com/suika/p/9063062.html