#P5467. [PKUSC2018] PKUSC
[PKUSC2018] PKUSC
题目描述
九条可怜是一个爱玩游戏的女孩子。
最近她在玩一个无双割草类的游戏,平面上有 个敌人,每一个敌人的坐标为 。可怜有一个技能是在平面上画一个 个点的简单多边形,并消灭所有严格在多边形内部的敌人。
不难发现如果想要快速的消灭敌人的话,只要画一个足够大的简单多边形就行了。但是这样的游戏性就太差了。于是可怜打算为游戏增加一定的随机性。
可怜在平面上随便画了一个 个点的简单多边形 。接下来可怜打算按照 上的均匀分布随机选取数字 (可以理解为等概率选取),并把这个简单多边形绕原点逆时针旋转 的角度(弧度制)。
现在可怜给你了每一个点的坐标,多边形的坐标,你的任务是帮助可怜计算在随机旋转后她期望可以消灭多少个敌人。
输入格式
第一行四个整数 。
接下来 行每行两个整数 描述了一个敌人的坐标。
接下来 行每行两个整数 按照逆时针的顺序描述了简单多边形的每一个顶点。
输出格式
输出一行一个整数表示期望值,保留五位小数。同时保证所有数据的小数点后第 位在舍入前不会是 和 。
4 4
0 0
1 0
-1 -1
0 1
0 0
1 0
1 1
0 1
0.50000
提示
样例解释
如果你对概率与期望不怎么了解,这儿给出一些 Hint:
- 设 为旋转之后恰好能消灭 个敌人的概率,那么期望就是 .
- 计算 的一个方法是,在所有 范围内的旋转角度中,旋转后恰好消灭 个敌人的角度构成了 个区间 (开闭不影响),那么 .
在这题中:能消灭 个敌人的区间是 ,能消灭 个敌人的区间是 。于是 。所以答案为 .
数据范围
对于 的数据,。
对于另外 的数据,选择的简单多边形是一个凸多边形。
对于 的数据,.