绕钉子的长绳子

背景

平面上有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 ;
}

最新文章

  1. ios AudioQueueStart returns -50 录音失败问题
  2. Redis资料汇总专题
  3. Core Animation中的组动画
  4. NYOJ 108 士兵杀敌1(树状数组)
  5. 关于PHP7
  6. cs331n 线性分类器损失函数与最优化
  7. springmvc的controller中使用@Transactional无效
  8. [ci]jenkins server启动,通过jnlp的方式启动slave(容器模式)
  9. Java String常用的两个方法
  10. Mysql优化要点
  11. 【AaronYang风格】第一篇 CodeFirst 初恋
  12. Selenium2+python自动化54-unittest生成测试报告(HTMLTestRunner)
  13. Systemd unit generators unit
  14. 95. Unique Binary Search Trees II (Tree; DFS)
  15. SQL聚集索引和非聚集索引的区别
  16. Spring、Spring Boot、Spring Frame、Spring MVC的区别
  17. C#使用事件方式Winform窗体之间传值
  18. manifest
  19. Leetcode12---&gt;Integer to Roman(整数转换为罗马数字)
  20. oracle删除数据库表空间

热门文章

  1. C语言进阶——注释符号12
  2. C# 不同窗口传递参数
  3. GCJ:2008 Round1AA-Minimum Scalar Product(有序数组倒序乘积和最小)
  4. 34-Cookie-based认证实现
  5. 20145202课后题,2.56&amp;9.16
  6. salt 通信及其安全
  7. PHP.22-Smart模版
  8. android 事件传递机制
  9. hive原理
  10. 怎么用 copy 关键字?