题目传送门

  传送点I

  传送点II

  传送点III

题目大意

  给定$n$的平面上的直线,保证没有三条直线共点,两条直线平行。问随机选出3条直线交成的三角形面积的期望。

  显然$S=\frac{1}{2}ah$是不可用的。(压根感觉不可优化)

  考虑向量的做法:$S = \frac{1}{2}(A \times B + B \times C + C\times A)$。(相当于把一个三角形拆成了三个以原点作为其中一个顶点的"有向"三角形)

  于是考虑利用向量叉积对向量加法的分配律进行优化。

  枚举第一条直线,剩下的直线按照极角序加入,不断计算交点和有向面积。

  对于直线的方向,我是根据原点在直线的哪一侧决定的。(比如定向后,原点在它左侧)

  然后画三条直线相交,讨论原点在哪,然后再讨论怎么计算有向面积。

  画一张图仅供参考,1和2表示是交点被计算的顺序。

  开心地发现原点在三角形内部的时候计算叉积的时候需要取相反数计入答案。

  这很烦。所以取一个超级远的地方的点作为原点就可以成功避开了这个问题。

Code

 /**
* Codeforces
* Problem#528E
* Accepted
* Time: 78ms
* Memory: 100k
*/
#include <bits/stdc++.h>
using namespace std;
typedef bool boolean; //Comparison of floating point constants
const double eps = 1e-;
//π
const double pi = acos((double)-); //Define the points and the vectors
typedef class Point {
public:
double x;
double y;
Point(const double x = 0.0, const double y = 0.0):x(x), y(y) { }
}Point, Vector; const Point O(1e7, 1e7); Vector operator + (Vector a, Vector b) {
return Vector(a.x + b.x, a.y + b.y);
} Vector operator - (Vector a, Vector b) {
return Vector(a.x - b.x, a.y - b.y);
} Vector operator * (Vector a, double b) {
return Vector(a.x * b, a.y * b);
} Vector operator * (double b, Vector a) {
return Vector(a.x * b, a.y * b);
} Vector operator / (Vector a, double b) {
return Vector(a.x / b, a.y / b);
} Vector operator - (Vector a) {
return Vector(-a.x, -a.y);
} int dcmp(double x) {
if(fabs(x) < eps) return ;
return (x < ) ? (-) : ();
} double Dot(Vector a, Vector b) {
return a.x * b.x + a.y * b.y;
} double Cross(Vector a, Vector b) {
return a.x * b.y - a.y * b.x;
} double Area(Point a, Point b, Point c) {
return fabs(Cross(b - a, c - a) / );
} Point getLineIntersection(Point A, Vector v, Point B, Vector u) {
Vector w = B - A;
double t = (Cross(w, u) / Cross(v, u));
return A + t * v;
} typedef class Line {
public:
Point p;
Vector v;
double ang;
int id; Line() { }
Line(int a, int b, int c, int id):id(id) {
if (!b) {
p = Point(c * 1.0 / a, );
v = Point(, );
} else {
p = Point(, c * 1.0 / b);
v = Point(-b, a);
}
if (Cross(O - p, v) > )
v = -v;
ang = atan2(v.y, v.x);
} boolean operator < (Line b) const {
return ang < b.ang;
}
}Line; ostream& operator << (ostream& os, Point p) {
os << "(" << p.x << " " << p.y << ")";
return os;
} int n;
Line *ls; inline void init() {
scanf("%d", &n);
ls = new Line[(n + )];
for (int i = , a, b, c; i <= n; i++) {
scanf("%d%d%d", &a, &b, &c);
ls[i] = Line(a, b, c, i);
}
} double res = 0.0;
inline void solve() {
sort(ls + , ls + n + );
// for (int i = 1; i <= n; i++)
// cerr << ls[i].p << " " << ls[i].v << " " << ls[i].ang << endl;
for (int i = ; i <= n; i++) {
Point sP(, ), P;
for (int j = i + ; j <= n; j++) {
P = getLineIntersection(ls[i].p, ls[i].v, ls[j].p, ls[j].v) - O;
// int d = dcmp(Cross(ls[i].v, ls[j].v));
res += Cross(sP, P);
sP = sP + P;
}
for (int j = ; j < i; j++) {
P = getLineIntersection(ls[i].p, ls[i].v, ls[j].p, ls[j].v) - O;
// int d = dcmp(Cross(ls[i].v, ls[j].v));
res += Cross(sP, P);
sP = sP + P;
}
}
printf("%.9lf", res * / n / (n - ) / (n - ));
} int main() {
init();
solve();
return ;
}

Codeforces 528E Triangles 3000 - 计算几何的更多相关文章

  1. 【CF528E】Triangles 3000(计算几何)

    [CF528E]Triangles 3000(计算几何) 题面 CF 平面上有若干条直线,保证不平行,不会三线共点. 求任选三条直线出来围出的三角形的面积的期望. 题解 如果一定考虑直接计算这个三角形 ...

  2. Codeforces 15E Triangles 【组合计数】

    Codeforces 15E Triangles Last summer Peter was at his granny's in the country, when a wolf attacked ...

  3. CodeForces 682E Alyona and Triangles (计算几何)

    Alyona and Triangles 题目连接: http://acm.hust.edu.cn/vjudge/contest/121333#problem/J Description You ar ...

  4. Codeforces Round #296 (Div. 1) E. Triangles 3000

    http://codeforces.com/contest/528/problem/E 先来吐槽一下,一直没机会进div 1, 马力不如当年, 这场题目都不是非常难,div 2 四道题都是水题! 题目 ...

  5. Codeforces 15E Triangles - 组合数学

    Last summer Peter was at his granny's in the country, when a wolf attacked sheep in the nearby fores ...

  6. ACM学习历程——UVA10112 Myacm Triangles(计算几何,多边形与点的包含关系)

    Description   Problem B: Myacm Triangles Problem B: Myacm Triangles Source file: triangle.{c, cpp, j ...

  7. CF528E Triangles 3000

    cf luogu 既然要求三角形面积,不如考虑三角形的面积公式.因为是三条直线,所以可以考虑利用三个交点来算面积,如果这个三角形按照逆时针方向有\(ABC\)三点,那么他的面积为\(\frac{\ve ...

  8. Codeforces Gym 100733A Shitália 计算几何

    ShitáliaTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/view.acti ...

  9. Codeforces Gym 100286A. Aerodynamics 计算几何 求二维凸包面积

    Problem A. AerodynamicsTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/co ...

随机推荐

  1. SharePoint Server 2019新特性

    .基于.NET4.7框架 功能基本是把office365的SPO功能搬家过来.如下: Sharepoint server 2019将在2018年发布 New web parts There were ...

  2. D5 F

    最近见到了好多跟排列有关的状压dp,好像略微会了一点,用 dp[i][s][j]表示第i位状态为s选择j的方案数,然后递推. 早起大概可以提高人的智商但是会导致人甚至不清,初始化写错了自闭了半个小时 ...

  3. thymeleaf(二)

    项目demo     http://pan.baidu.com/s/1wg6PC 学习资料网址  http://www.blogjava.net/bjwulin/archive/2013/02/07/ ...

  4. phpcms栏目标签调用

    $CATEGORY[$catid][catid]                栏目id   $CATEGORY[$catid][module]                栏目所在的模块   $C ...

  5. 10、DOM(文档对象模型)

    1.认识DOM html    骨架 css     装修 javascript 物业 ==DOM 打破上述三者的通道.== [注]script标签一般情况下要写在head标签. <div id ...

  6. 唉,可爱的小朋友---(DFS)

    唉,小朋友是比较麻烦的.在一个幼儿园里,老师要上一节游戏课,有N个小朋友要玩游戏,做游戏时要用小皮球,但是幼儿园里只有M个小皮球,而且有些小朋友不喜欢和一些小朋友在一起玩,而只喜欢和另一些小朋友一起玩 ...

  7. 利用python+selenium在pycharm下进行页面登陆的半自动测试

    很久没有写了,现在正式入职,准备好好干,加油! 我的第一个较正式的测试代码: from selenium import webdriverimport unittestimport sysimport ...

  8. python语法_使用占位符进行格式化输出

    “%s”   占位符 name = input("name:") age = input("age:") job = input("job:" ...

  9. OA流程分析

    OA流程分析: 1. 流程定义:可视化可拖拽的流程环节设置,流程定义完成后保存在数据表中,字段有流程ID,名称,流程流转环节. 2. 画业务表单,新建业务数据表. 3. 表单数据填好后,启动流程:

  10. [httpd] httpd server 在低负载的情况下对SYN无响应

    如题: 两台client通过load balance访问httpd server.两个client交互访问.load balance处于fullnat模式. server在低负载情况下,常常对某一个c ...