2015ACM-ICPC长春E题(hdu5531)题解
一、题意
No response.T_T
二、思路
分$n$为奇数或者偶数讨论。
如果$n$是奇数,列出不等式组:$r_1+r_2=d_{1},r_2+r_3=d_{2},r_3+r_4=d_{3},\cdots,r_{n-1}+r_n=d_{n-1},r_n+r_1=d_n$,可以解出,$r_1=\frac{d_{1}+d_{3}+d_{5}+\cdots-d_{2}-d_{4}-\cdots}{2}$,然后再用上述式子依次算出$r_2$至$r_n$。最后判断$r_1$至$r_n$中是否存在负数即可。
如果$n$是偶数。如果奇数起点的边之和$s_1=d_1+d_3+d_5+\cdots+d_{n-1}$不等于$s_2=d_2+d_4+d_6+\cdots+d_n$,说明无解,否则,一定可以三分枚举出$r_1$,然后推出其他半径。要注意的是,三分的下界和上界需要处理出来。否则,面积关于$r_1$的二次函数在$[low,high]$区间内不一定只有一个极小值。最后判断是否所有半径都大于$0$。
三、代码
#include<bits/stdc++.h>
using namespace std;
);
struct point {
double x, y;
} p[];
], ansr[];
int n;
inline bool eq(double x, double y) {
);
}
inline double dis(point a, point b) {
return hypot(a.x - b.x, a.y - b.y);
}
double calc(double r1) {
ansr[] = r1;
double sum = PI * r1 * r1, nr;
; i <= n; ++i) {
ansr[i] = d[i - ] - ansr[i - ];
sum += PI * ansr[i] * ansr[i];
}
return sum;
}
int main() {
// freopen("e.in", "r", stdin);
int T;
for(scanf("%d", &T); T--;) {
;
scanf("%d", &n);
; i <= n; ++i)scanf("%lf %lf", &p[i].x, &p[i].y);
; i <= n; ++i)d[i] = dis(p[i], i < n ? p[i + ] : p[]);
) {
;
; i <= n; i++) {
)fz += d[i];
else fz -= d[i];
}
ansr[] = fz / ;
; i <= n; ++i)ansr[i] = d[i - ] - ansr[i - ];
] + ansr[n], d[n]))imp = ;
}
else {
, t2 = ;
; i <= n; ++i) {
)t1 += d[i];
else t2 += d[i];
}
;
else {
, high = min(d[], d[n]), lmid, rmid, s1, s2, sum = ;
; i <= n; ++i) {
)sum += d[i], high = min(high, sum);
else sum -= d[i], low = max(low, sum);
}
;
while(ttt--) {
lmid = (low + high) / ;
rmid = (lmid + high) / ;
s1 = calc(lmid), s2 = calc(rmid);
if(s1 < s2)high = rmid;
else low = lmid;
}
double r1;
if(calc(low) < calc(high))r1 = low;
else r1 = high;
calc(r1);
}
}
; i <= n; ++i) {
)imp = ;
}
if(imp) puts("IMPOSSIBLE");
else {
;
; i <= n; ++i)ans += ansr[i] * ansr[i];
ans *= PI;
printf("%.2f\n", ans);
; i <= n; ++i)printf("%.2f\n", ansr[i]);
}
}
;
}
2015ACM-ICPC长春E题(hdu5531)题解的更多相关文章
- 2015ACM/ICPC亚洲区沈阳站 部分题解
链接在这:http://bak.vjudge.net/contest/132442#overview. A题,给出a,b和n,初始的集合中有a和b,每次都可以从集合中选择不同的两个,相加或者相减,得到 ...
- 2015ACM/ICPC亚洲区长春站 L hdu 5538 House Building
House Building Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others) ...
- 2015ACM/ICPC亚洲区长春站 B hdu 5528 Count a * b
Count a * b Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Tot ...
- (HDU 5558) 2015ACM/ICPC亚洲区合肥站---Alice's Classified Message(后缀数组)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=5558 Problem Description Alice wants to send a classi ...
- 2015ACM/ICPC亚洲区长春站 J hdu 5536 Chip Factory
Chip Factory Time Limit: 18000/9000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)T ...
- 2015ACM/ICPC亚洲区长春站 H hdu 5534 Partial Tree
Partial Tree Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)To ...
- 2015ACM/ICPC亚洲区长春站 G hdu 5533 Dancing Stars on Me
Dancing Stars on Me Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Ot ...
- 2015ACM/ICPC亚洲区长春站 F hdu 5533 Almost Sorted Array
Almost Sorted Array Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Ot ...
- 2015ACM/ICPC亚洲区长春站 E hdu 5531 Rebuild
Rebuild Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total S ...
随机推荐
- C# zedgraph利用另一窗口取得的串口数据绘图
C# zedgraph利用另一窗口获得的串口数据绘图第一次用zedgraph,非常不熟悉,网上很多内容看的云里雾里... 这个程序主界面接收串口数据,而另外一个窗口进行实时曲线绘图,要怎么样实现for ...
- MyEclipse怎么导入导出项目
MyEclipse怎么导入导出项目 | 浏览:25271 | 更新:2012-06-06 17:48 1 2 3 4 5 6 7 分步阅读 MyEclipse,是一个十分优秀的功能强大的JavaEE的 ...
- Python 文件复制_bytes
f1 = open("c:/huyifei.jpg", mode="rb") f2 = open("d:/huerfei.jpg", mod ...
- Swift中获取系统语言
//en-US zh-HK zh-TW zh-Hans-US var lng:String { let userDefault = NSUserDefaults.standardUserDefault ...
- Linux下mysql操作
1.linux下MYSQL的启动与访问 http://www.cnblogs.com/hunter007/articles/2251795.html 2.linux下mysql基本的操作 http:/ ...
- Ubuntu16.04怎样安装Python3.6
Ubuntu16.04默认安装了Python2.7和3.5 请注意,系统自带的python千万不能卸载! 输入命令python
- 【计算机视觉】ARM平台实现人脸检测YSQfastfd
ARM平台实现于仕琪人脸检测库YSQfastfd 平台要求 ARM32 platform hardware board Ubuntu 16.04 with GTK3 library USB camer ...
- ADC复用重映射
- Codeforces 1096G. Lucky Tickets【生成函数】
LINK 题目大意 很简单自己看 思路 考虑生成函数(为啥tags里面有一个dp啊) 显然,每一个指数上是否有系数是由数集中是否有这个数决定的 有的话就是1没有就是0 然后求出这个生成函数的\(\fr ...
- BZOJ4475: [Jsoi2015]子集选取【找规律】【数学】
Description Input 输入包含一行两个整数N和K,1<=N,K<=10^9 Output 一行一个整数,表示不同方案数目模1,000,000,007的值. Sample In ...