Vijos P1007 绕钉子的长绳子
2024-10-21 05:50:31
绕钉子的长绳子
背景
平面上有N个圆柱形的大钉子,半径都为R,所有钉子组成一个凸多边形。
现在你要用一条绳子把这些钉子围起来,绳子直径忽略不计。
描述
求出绳子的长度
格式
输入格式
第1行两个数:整数N(1<=N<=100)和实数R。
接下来N行按逆时针顺序给出N个钉子中心的坐标
坐标的绝对值不超过100。
输出格式
一个数,绳子的长度,精确到小数点后2位。
样例1
样例输入1
4 1
0.0 0.0
2.0 0.0
2.0 2.0
0.0 2.0
样例输出1
14.28
限制
各个测试点1s
提示
如果你用比较复杂的方法AC了,请想一想有没有更加简便的方法。
来源
Ural
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#define maxn 110
double x[maxn],y[maxn],R,ans;
int n;
int main(){
scanf("%d%lf",&n,&R);
for(int i=;i<=n;i++)
scanf("%lf%lf",&x[i],&y[i]);
for(int i=;i<=n;i++){
ans+=sqrt((x[i]-x[i-])*(x[i]-x[i-])+
(y[i]-y[i-])*(y[i]-y[i-]));
}
ans+=sqrt((x[n]-x[])*(x[n]-x[])+
(y[n]-y[])*(y[n]-y[]));
ans+=R**3.14159;
printf("%.2lf",ans);
return ;
}
最新文章
- ios AudioQueueStart returns -50 录音失败问题
- Redis资料汇总专题
- Core Animation中的组动画
- NYOJ 108 士兵杀敌1(树状数组)
- 关于PHP7
- cs331n 线性分类器损失函数与最优化
- springmvc的controller中使用@Transactional无效
- [ci]jenkins server启动,通过jnlp的方式启动slave(容器模式)
- Java String常用的两个方法
- Mysql优化要点
- 【AaronYang风格】第一篇 CodeFirst 初恋
- Selenium2+python自动化54-unittest生成测试报告(HTMLTestRunner)
- Systemd unit generators unit
- 95. Unique Binary Search Trees II (Tree; DFS)
- SQL聚集索引和非聚集索引的区别
- Spring、Spring Boot、Spring Frame、Spring MVC的区别
- C#使用事件方式Winform窗体之间传值
- manifest
- Leetcode12--->;Integer to Roman(整数转换为罗马数字)
- oracle删除数据库表空间