2829: 信用卡凸包

Description

Input

Output

Sample Input

2
6.0 2.0 0.0
0.0 0.0 0.0
2.0 -2.0 1.5707963268

Sample Output

21.66

HINT

本样例中的2张信用卡的轮廓在上图中用实线标出,如果视1.5707963268为

Pi/2(pi为圆周率),则其凸包的周长为16+4*sqrt(2)

【分析】

  乍一看还是不会做hh。

  把那个圆拿出来,做凸包,最后再加一个圆形的周长就好了。

  至于为什么,我还是看黄学长博客的,只能意会一下,不会证明,但是我觉得应该是把凸包向外平移然后凸多边形外角和等于360度,说明外面可以拼成一个完整的圆吧。

  所以一开始a-=2*r,b-=2*r。

  说一下旋转那部分,傻傻地画图搞了很久,用向量就会很方便。

  设a和b的夹角是y,要旋转的角是x。

  假设中心点在原点,最后再平移。一开始不旋转的时候是(b/2,a/2)

  设r*r=a*a+b*b

  新点(r*cos(x+y),r*sin(x+y)) -> (r*cosx*cosb-r*sinx*sinb,r*sinx*sinb+r*cosx*sinb) -> (b/2*cosx-a/2*sinx)

  其他三个点类似。

 #include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
#define Maxn 400010 const double eps=0.00001;
const double pi=3.14159265; struct P
{
double x,y;
}t[Maxn],w[Maxn];
int len,wl;
double a,b,r; P operator - (P a,P b)
{
P tt;
tt.x=a.x-b.x;tt.y=a.y-b.y;
return tt;
} /*P rot(P x,double d,double c)
{
P nw;
nw.x=x.x+d*cos(c);
nw.y=x.y+d*sin(c);
return nw;
}*/ P rot(double x,double y,P nw,double c)
{
P ans;
ans.x=x+nw.x*cos(c)-nw.y*sin(c);
ans.y=y+nw.x*sin(c)+nw.y*cos(c);
return ans;
} void make_p(double x,double y,double c)
{
P nw;
nw.x=b/,nw.y=a/; t[++len]=rot(x,y,nw,c);
nw.x=-b/,nw.y=a/; t[++len]=rot(x,y,nw,c);
nw.x=b/,nw.y=-a/; t[++len]=rot(x,y,nw,c);
nw.x=-b/,nw.y=-a/; t[++len]=rot(x,y,nw,c);
/*for(int k=0;k<4;k++)
{
nw.x=x;nw.y=y;
P now=rot(nw,b/2,k*pi/2+c);
t[++len]=rot(now,a/2,(k+1)*pi/2+c);
double tt;
tt=a;a=b;b=tt;
}*/
} double myabs(double x) {return x>?x:-x;} int fbs(double x)
{
if(myabs(x)<=eps) return ;
else return x>?:-;
} bool cmp(P x,P y) {return fbs(x.x-y.x)==?(x.y<y.y):(x.x<y.x);}
double Dot(P x,P y) {return x.x*y.x+x.y*y.y;}
double Cross(P x,P y) {return x.x*y.y-x.y*y.x;} void chull()
{
sort(t+,t++len,cmp);
wl=;
for(int i=;i<=len;i++)
{
while(wl>&&Cross(w[wl]-w[wl-],t[i]-w[wl])<=) wl--;
w[++wl]=t[i];
}
int k=wl;
for(int i=len-;i>=;i--)
{
while(wl>k&&Cross(w[wl]-w[wl-],t[i]-w[wl])<=) wl--;
w[++wl]=t[i];
}
wl--;
} double get_length()
{
double ans=;
for(int i=;i<wl;i++)
{
ans+=sqrt(Dot(w[i]-w[i+],w[i]-w[i+]));
}
ans+=sqrt(Dot(w[wl]-w[],w[wl]-w[]));
return ans;
} int main()
{
int n;
scanf("%d",&n);
scanf("%lf%lf%lf",&a,&b,&r);a-=*r;b-=*r;
len=;
for(int i=;i<=n;i++)
{
double x,y,c;
scanf("%lf%lf%lf",&x,&y,&c);
make_p(x,y,c);
}
chull();
double ans=get_length();
ans+=*r*pi;
printf("%.2lf\n",ans);
return ;
}

2016-12-13 18:38:01

【BZOJ 2829】 2829: 信用卡凸包 (凸包)的更多相关文章

  1. BZOJ2829信用卡凸包——凸包

    题目描述 输入 输出 样例输入 2 6.0 2.0 0.0 0.0 0.0 0.0 2.0 -2.0 1.5707963268 样例输出 21.66 提示 本样例中的2张信用卡的轮廓在上图中用实线标出 ...

  2. luogu P3829 [SHOI2012]信用卡凸包 凸包 点的旋转

    LINK:信用卡凸包 当 R==0的时候显然是一个点的旋转 之后再求凸包即可. 这里先说点如何旋转 如果是根据原点旋转的话 经过一个繁杂的推导可以得到一个矩阵. [cosw,-sinw] [sinw, ...

  3. BZOJ 2388: 旅行规划 [分块 凸包 等差数列]

    传送门 题意: 区间加和询问一段区间内整体前缀和的最大值 刚才还在想做完这道题做一道区间加等差数列结果发现这道就是.... 唯一的不同在于前缀和一段区间加上等差数列后,区间后面也要加上一个常数!!! ...

  4. 【bzoj2829】信用卡凸包 凸包

    题目描述 输入 输出 样例输入 26.0 2.0 0.00.0 0.0 0.02.0 -2.0 1.5707963268 样例输出 21.66 题解 凸包 傻逼题,答案显然为:所有圆心构成的凸包周长+ ...

  5. bzoj 2300: [HAOI2011]防线修建 凸包

    题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=2300 题解 这道题让我们维护一个支持动态删除点的上凸壳 并且告诉了我们三个一定不会被删除 ...

  6. bzoj 1069: [SCOI2007]最大土地面积 凸包+旋转卡壳

    题目大意: 二维平面有N个点,选择其中的任意四个点使这四个点围成的多边形面积最大 题解: 很容易发现这四个点一定在凸包上 所以我们枚举一条边再旋转卡壳确定另外的两个点即可 旋(xuan2)转(zhua ...

  7. bzoj 2961 共点圆 cdq+凸包+三分

    题目大意 两种操作 1)插入一个过原点的圆 2)询问一个点是否在所有的圆中 分析 在圆中则在半径范围内 设圆心 \(x,y\) 查询点\(x_0,y_0\) 则\(\sqrt{(x-x_0)^2+(y ...

  8. bzoj 2087: [Poi2010]Sheep【凸包+极角排序+dp】

    首先处理处理出来哪些边能连--能把羊分成两个偶数部分的,实现是在凸包上枚举极点,极角排序,枚举凸包上点对判断两边羊的个数的奇偶即可,设可以连边为v[i][j]=1 然后设f[i][j]为从i到j个凸包 ...

  9. bzoj 1027: [JSOI2007]合金【凸包+Floyd】

    参考:https://www.cnblogs.com/zhuohan123/p/3237246.html 因为一c可以由1-a-b得出,所以删掉c,把a,b抽象成二维平面上的点.首先考虑一个客户需求能 ...

  10. hdu4273Rescue(三维凸包重心)

    链接 模板题已不叫题.. 三维凸包+凸包重心+点到平面距离(体积/点积)  体积-->混合积(先点乘再叉乘) #include <iostream> #include<cstd ...

随机推荐

  1. iOS开发——iOS10升级极光推送SDK、友盟分享SDK

    前不久升级了Xcode8 ,同时iOS10系统也推送久. 由于公司需要适配iOS 10系统,同时第三方sdk建议升级. 包含替换升级新的SDK和相应的代码修改. 主要分享如何升级极光推送SDK,友盟分 ...

  2. UIPickerView常见属性、常见方法(包括代理方法和数据源方法)的一些说明

    一.UIPickerView 1.UIPickerView的常见属性 // 数据源(用来告诉UIPickerView有多少列多少行) @property(nonatomic,assign) id< ...

  3. OC5_NSFileManger

    // // main.m // OC5_NSFileManger // // Created by zhangxueming on 15/6/19. // Copyright (c) 2015年 zh ...

  4. CMakeLists实战解读--YouCompleteMe

    原文转载自:Ricky.K http://www.cnblogs.com/rickyk/p/3877238.html 个人一直有一个想法,就是想出一系列关于CMakeLists.txt国外经典例子的实 ...

  5. jQuery自己编写插件()

    引言: 在项目中不同页面经常要用到已经写好的交互,比如弹窗,比如下拉菜单,比如选项卡,比如删除... 此时如果每次都把代码copy一份无疑是一件比较麻烦并且无趣的事情,而且个人认为有些low了,我们可 ...

  6. ToolStripStatusLabel设置时间自动更新

    在使用委托设置界面上ToolStripStatusLabel类型的控件时间是,发现不能使用自定义的委托方法,在往上查找了一下发现不能使用involve来线程调用.因此只能使用原生委托方法. //代理p ...

  7. mysql中使用update select

    UPDATE t_user INNER JOIN t_shake ON t_shake.user_id = t_user.user_id SET t_user.shake_total_num = t_ ...

  8. ecshop改造读写分离配置与改造

    前两天配置好了mysql主从方式,今天就拿ecshop练习读写分离.以下代码仅供学习参考,不成熟的地方,还需完善. <?php $db_name = "ecshop"; $p ...

  9. Catalyst揭秘 Day4 analyzer解析

    Catalyst揭秘 Day4 analyzer解析 今天继续解析catalyst,主要讲一下analyzer,在sql语句的处理流程中,analyzer是在sqlparse的基础上,把unresol ...

  10. IBM MQ

    一,安装 1,先安装必备MQ\MQ60\Prereqs\IES\Setup.exe 2,再安装MQ\MQParms.exe 二,发送方 刚装好后,默认有一个管理器名,可以删除,自己重新建,以防有不可知 ...