BZOJ2829信用卡凸包——凸包
题目描述
.jpg)
输入
.jpg)
输出
.jpg)
样例输入
6.0 2.0 0.0
0.0 0.0 0.0
2.0 -2.0 1.5707963268
样例输出
提示
.jpg)
本样例中的2张信用卡的轮廓在上图中用实线标出,如果视1.5707963268为
Pi/2(pi为圆周率),则其凸包的周长为16+4*sqrt(2)
我们先将每个信用卡看成是由四个圆心组成的矩形,那么凸包就是所有圆心形成的凸包。现在每个圆心往外扩展为一个圆,那么就是用凸包来包住所有的圆,而新的凸包的直边部分就是原凸包对应边往外平移得到。对于曲面部分,因为一个凸多边形外角和为360度,所以曲面部分就是一个圆的周长。直接求所有圆心形成凸包的周长再加上一个圆的周长即可。
#include<set>
#include<map>
#include<queue>
#include<stack>
#include<cmath>
#include<cstdio>
#include<vector>
#include<bitset>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const double pi=acos(-1.0);
struct lty
{
double x,y;
lty(double X=0,double Y=0){x=X,y=Y;}
}a[40010];
lty operator -(lty a,lty b){return lty(a.x-b.x,a.y-b.y);}
double operator *(lty a,lty b){return a.x*b.y-b.x*a.y;}
int st[40010];
int vis[40010];
int top;
int n;
int cnt;
double x,y,r;
double X,Y,R;
double ans;
lty res;
bool cmp(lty a,lty b)
{
return a.x==b.x?a.y<b.y:a.x<b.x;
}
int main()
{
scanf("%d",&n);
scanf("%lf%lf%lf",&X,&Y,&R);
X=X/2-R,Y=Y/2-R;
for(int i=1;i<=n;i++)
{
scanf("%lf%lf%lf",&x,&y,&r);
a[++cnt]=lty(x+Y*cos(r)+X*sin(r),y+Y*sin(r)-X*cos(r));
a[++cnt]=lty(x-Y*cos(r)+X*sin(r),y-Y*sin(r)-X*cos(r));
a[++cnt]=lty(x+Y*cos(r)-X*sin(r),y+Y*sin(r)+X*cos(r));
a[++cnt]=lty(x-Y*cos(r)-X*sin(r),y-Y*sin(r)+X*cos(r));
}
sort(a+1,a+1+cnt,cmp);
st[++top]=1;
for(int i=2;i<=cnt;i++)
{
while(top>1&&(a[st[top]]-a[st[top-1]])*(a[i]-a[st[top]])<=0)
{
vis[st[top--]]=0;
}
vis[i]=1;
st[++top]=i;
}
int lim=top;
for(int i=cnt-1;i>=1;i--)
{
if(!vis[i])
{
while(top>lim&&(a[st[top]]-a[st[top-1]])*(a[i]-a[st[top]])<=0)
{
vis[st[top--]]=0;
}
vis[i]=1;
st[++top]=i;
}
}
for(int i=1;i<top;i++)
{
res=a[st[i+1]]-a[st[i]];
ans+=sqrt(res.x*res.x+res.y*res.y);
}
printf("%.2f",ans+2*pi*R);
}
BZOJ2829信用卡凸包——凸包的更多相关文章
- [BZOJ2829] 信用卡 (凸包)
		
[BZOJ2829] 信用卡 (凸包) 题面 信用卡是一个矩形,唯四个角做了圆滑处理,使他们都是与矩形两边相切的1/4园,如下图所示,现在平面上有一些规格相同的信用卡,试求其凸包的周长.注意凸包未必是 ...
 - Bzoj2829 信用卡凸包
		
Time Limit: 10 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 333 Solved: 155 Description Input ...
 - BZOJ-2829 信用卡凸包
		
凸包题. 我们先把所有信用卡的四个定点的坐标求出来,然后计算凸包长度,最后加上一个圆的周长就行. #include <cstdlib> #include <cstdio> #i ...
 - 2019.02.21 bzoj2829: 信用卡凸包(凸包)
		
传送门 题意:给nnn个A∗BA*BA∗B的矩形,其中每个矩形的四个角被改造成了半径为rrr的四分之一 圆,问这些矩形的凸包周长. 思路:考虑求出圆心的凸包周长然后加上一个整圆的周长,证明很简单,略掉 ...
 - 【bzoj2829】信用卡凸包  凸包
		
题目描述 输入 输出 样例输入 26.0 2.0 0.00.0 0.0 0.02.0 -2.0 1.5707963268 样例输出 21.66 题解 凸包 傻逼题,答案显然为:所有圆心构成的凸包周长+ ...
 - 【计算几何】【凸包】bzoj2829 信用卡凸包
		
http://hzwer.com/6330.html #include<cstdio> #include<cmath> #include<algorithm> us ...
 - luogu P3829 [SHOI2012]信用卡凸包 凸包 点的旋转
		
LINK:信用卡凸包 当 R==0的时候显然是一个点的旋转 之后再求凸包即可. 这里先说点如何旋转 如果是根据原点旋转的话 经过一个繁杂的推导可以得到一个矩阵. [cosw,-sinw] [sinw, ...
 - hdu4273Rescue(三维凸包重心)
		
链接 模板题已不叫题.. 三维凸包+凸包重心+点到平面距离(体积/点积) 体积-->混合积(先点乘再叉乘) #include <iostream> #include<cstd ...
 - HDU 1392 Surround the Trees (凸包周长)
		
题目链接:HDU 1392 Problem Description There are a lot of trees in an area. A peasant wants to buy a rope ...
 
随机推荐
- ASP.NET Core依赖注入——依赖注入最佳实践
			
在这篇文章中,我们将深入研究.NET Core和ASP.NET Core MVC中的依赖注入,将介绍几乎所有可能的选项,依赖注入是ASP.Net Core的核心,我将分享在ASP.Net Core应用 ...
 - C#.NET 大型通用信息化系统集成快速开发平台 4.1 版本 - 即时消息提醒功能改进
			
可以给自己的信息管理系统增加一些即时消息提醒功能,简单方便,一般是一行代码就可以发送提醒信息了,方便二次开发,个性化改进. 1:可以用简拼,快速查找内部员工. 2:双击直接可以发QQ消息. 3:双击直 ...
 - from bs4 import BeautifulSoup 报错
			
一: BeautifulSoup的安装: 下载地址:https://www.crummy.com/software/BeautifulSoup/bs4/download/4.6/ 下载后,解压缩,然后 ...
 - 广州商学院16级软工一班&二班-第二次作业成绩
			
作业地址 https://edu.cnblogs.com/campus/gzcc/GZCC-16SE2/homework/2097 https://edu.cnblogs.com/campus/gzc ...
 - Dapper.NET
			
关于Dapper.NET的相关论述 年少时,为何不为自己的梦想去拼搏一次呢?纵使头破血流,也不悔有那年少轻狂.感慨很多,最近事情也很多,博客也很少更新了,毕竟每个人都需要为自己的生活去努力. 最近 ...
 - static特别用法【静态导包】——Java包的静态导入
			
面试我问你static关键字有哪些作用,如果你答出static修饰变量.修饰方法我会认为你合格,答出静态块,我会认为你不错,答出静态内部类我会认为你很好,答出静态导包我会对你很满意,因为能看出你非常热 ...
 - CentOS6.5配置 cron
			
CentOS6.5配置 cron 任务 - mengjiaoduan的博客 - CSDN博客https://blog.csdn.net/mengjiaoduan/article/details/649 ...
 - 父级div宽度100%,子级一个div宽度固定,另一个宽度自适应
			
<!DOCTYPE html> <html> <head> <title>布局测试</title> <style type=" ...
 - css行内省略号、垂直居中
			
应用场景分析: 一.当你的文字限定行数,超出部分的文字用省略号显示. (有两个使用场景:1.单行 2.多行) // 单行 overflow: hidden; text-overflow:ellipsi ...
 - mysql异常:Packet for query is too large (10240 > 1024). You can change this value
			
出现这个问题的原因是:mysql的配置文件中 max_allowed_packet 设置过小,mysql根据配置文件会限制server接受的数据包大小. 还有人会说我操作的数据量明显没有超过这个值为啥 ...