月下柠檬树

题意

求n个圆与他们的公切线的定积分。

解法

求出圆的公切线就可以了。

特别坑的一点

最两端的圆,有可能会被其他的圆所包含,所以要重新求一下最左端与最右端。

比较坑的一点

精度要设小一点,不然会TLE。

代码如下:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <cctype>
#define INF 2139062143
#define MAX 0x7ffffffffffffff
#define del(a,b) memset(a,b,sizeof(a))
using namespace std;
typedef long long ll;
template<typename T>
inline void read(T&x)
{
x=0;T k=1;char c=getchar();
while(!isdigit(c)){if(c=='-')k=-1;c=getchar();}
while(isdigit(c)){x=x*10+c-'0';c=getchar();}x*=k;
}
const int maxn=(500+5)*2;
struct cir{
double x,r;
double h(double k){
double d=fabs(k-x);
return sqrt(r*r - d*d);
}
}c[maxn];
struct lin{
// y=kx+b
double k,b,lx,ly;
double h(double x){
return x*k+b;
}
}p[maxn];
int n;
double F(double x){
double ans=0.0;
for(int i=1;i<=n;i++){
if(x>(c[i].x-c[i].r)&&x<(c[i].x+c[i].r))
ans=max(ans,c[i].h(x));
}
for(int i=1;i<n;i++){
if(x>=p[i].lx&&x<=p[i].ly)
ans=max(ans,p[i].h(x));
}
return ans;
}
double simpson(double a,double b){
double mid=(a+b)/2;//*0.5???
return ( F(a) + 4*F(mid) + F(b) ) * (b-a)/6;
}
double asr(double a,double b,double eps,double A){
double mid = (a+b)/2;
double L = simpson(a,mid) , R = simpson(mid,b);
if(fabs(L+R-A) <= 15*eps) return L+R+(L+R-A)/15;
return asr(a,mid,eps/2,L) + asr(mid,b,eps/2,R);
}
double asr(double l,double r,double eps){
return asr(l,r,eps,simpson(l,r));
}
double alpha;
double h[maxn];
int main()
{
scanf("%d%lf",&n,&alpha);n++;
alpha= 1.0 / tan(alpha);
for(int i=1;i<=n;i++) scanf("%lf",&h[i]);
for(int i=1;i<n;i++) scanf("%lf",&c[i].r);c[n].r=0.0;
for(int i=1;i<=n;i++) c[i].x=c[i-1].x+h[i];
for(int i=1;i<=n;i++) c[i].x*=alpha; for(int i=1;i<n;i++){
if((c[i+1].x+c[i+1].r)<=(c[i].x+c[i].r)) continue;
if(fabs(c[i].r-c[i+1].r)<=1e-6){
p[i].lx=c[i].x,p[i].ly=c[i+1].x;
p[i].k=0.0;p[i].b=c[i].r;
continue;
}
if(c[i].r<c[i+1].r){
double _cos=(c[i+1].r-c[i].r)/(c[i+1].x-c[i].x);
double d=_cos*c[i+1].r;
double y2 = sqrt(c[i+1].r*c[i+1].r - d*d);
p[i].ly=c[i+1].x-d;
d=_cos*c[i].r;
double y1 = sqrt(c[i].r*c[i].r - d*d);
p[i].lx=c[i].x-d;
p[i].k = (y1-y2)/(p[i].lx-p[i].ly);
p[i].b = y1 - p[i].k*p[i].lx;
}
else{
double _cos=(c[i].r-c[i+1].r)/(c[i+1].x-c[i].x);
double d=_cos*c[i].r;
p[i].lx=c[i].x+d;
double y1 = sqrt(c[i].r*c[i].r - d*d);
d=_cos*c[i+1].r;
double y2 = sqrt(c[i+1].r*c[i+1].r - d*d);
p[i].ly=c[i+1].x+d;
p[i].k = (y1-y2)/(p[i].lx-p[i].ly);
p[i].b = y1 - p[i].k*p[i].lx;
}
}
//*****
double ll=c[1].x-c[1].r,rr=c[n].x;
for(int i=1;i<=n;i++){
double l=c[i].x-c[i].r,r=c[i].x+c[i].r;
ll=min(l,ll);rr=max(rr,r);
}
printf("%.2lf",2*asr(ll,rr,1e-6));
return 0;
}

【bzoj 1502】月下柠檬树的更多相关文章

  1. BZOJ 1502 月下柠檬树(simpson积分)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1502 题意:给出如下一棵分层的树,给出每层的高度和每个面的半径.光线是平行的,与地面夹角 ...

  2. BZOJ 1502 月下柠檬树(simpson积分)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1502 题意:给出如下一棵分层的树,给出每层的高度和每个面的半径.光线是平行的,与地面夹角 ...

  3. bzoj 1502 月下柠檬树【Simpson积分】

    投影到地面之后,会发现圆形在平行光下面积和形状是不会变的,也就是所要求的图形是若干个圆和把相邻两个圆连起来的公切线所组成的. 公切线和圆间距瞎求一下就行,注意要去掉被完全覆盖的圆 然后simpson即 ...

  4. BZOJ 1502: [NOI2005]月下柠檬树 [辛普森积分 解析几何 圆]

    1502: [NOI2005]月下柠檬树 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1070  Solved: 596[Submit][Status] ...

  5. 【BZOJ-1502】月下柠檬树 计算几何 + 自适应Simpson积分

    1502: [NOI2005]月下柠檬树 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1017  Solved: 562[Submit][Status] ...

  6. [NOI2005]月下柠檬树[计算几何(simpson)]

    1502: [NOI2005]月下柠檬树 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1169  Solved: 626[Submit][Status] ...

  7. [BZOJ1502]月下柠檬树(自适应辛普森积分)

    1502: [NOI2005]月下柠檬树 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1387  Solved: 739[Submit][Status] ...

  8. [NOI2005]月下柠檬树

    题意 F.A.Qs Home Discuss ProblemSet Status Ranklist Contest 入门OJ ModifyUser  autoint Logout 捐赠本站 Probl ...

  9. 【BZOJ1502】[NOI2005]月下柠檬树 Simpson积分

    [BZOJ1502][NOI2005]月下柠檬树 Description 李哲非常非常喜欢柠檬树,特别是在静静的夜晚,当天空中有一弯明月温柔地照亮地面上的景物时,他必会悠闲地坐在他亲手植下的那棵柠檬树 ...

随机推荐

  1. [luogu4053 JSOI2007] 建筑抢修 (贪心 优先队列)

    传送门 题目描述 小刚在玩JSOI提供的一个称之为"建筑抢修"的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的入侵者.但是T部落的基地里已经有N个建筑设施受到了严重的损伤 ...

  2. 中国电信线CTF线下选拨writeup

    [盟军密码|30分] 二战时盟军截获德军一段密码,密文为:0000011000000000101010110111000011000111100011110001001100111000111001( ...

  3. vue与animate.css的结合使用

    在vue项目中,由于页面需要动画效果,使用动画其实有多种方式,可以使用vue中的过渡transition,可以使用animate动画与transition配合使用,也可以单独使用animate动画库. ...

  4. Python设计模式--单例模式(懒汉式)

    1. 单例模式 --> 单一(唯一)的实例. 在整个运行时间内, 内存中只有一个对象, 一般该对象涉及网络,资源等操作. 2. 单例模式一般分为懒汉式和饿汉式 懒汉式内存占用更加合理. 3. 调 ...

  5. 在windows环境中关于 pycharm配置 anaconda 虚拟环境

    因为要在windows系统系统中练习tensorflow,所以需要配置一下环境(来回的开关机切换环境太麻烦了......) 首先安装anaconda3,我选择的版本是Anaconda3 5.1.0,对 ...

  6. 轻量级Java EE开发框架设计系统应用架构

    首先来说一下Java EE 概述 其中常说的三大框架即是:ssh Spring:功能强大的组件粘合济,能够将你的所有的java功能模块用配置文件的方式组合起来(还让你感觉不到spring的存在)成为一 ...

  7. Tensorflow 之物体检测

    1)安装Protobuf TensorFlow内部使用Protocol Buffers,物体检测需要特别安装一下. # yum info protobuf protobuf-compiler 2.5. ...

  8. 2015 Multi-University Training Contest 8 hdu 5383 Yu-Gi-Oh!

    Yu-Gi-Oh! Time Limit: 2000ms Memory Limit: 65536KB This problem will be judged on HDU. Original ID:  ...

  9. C#中的Dynamic

    dynamic dyn = (dynamic)1; int j = (int)dyn; 可以看到1被强制转换成dynamic,然后又被强制转换回int. 然而dynamic可以隐式的转换成任何类型,并 ...

  10. 使用postman 测试restful接口

    前提: 在chrome网上应用商店安装postman 和 Postman Interceptor. 如下图: 使用postman的时候,最后开启postman Interceptor,如下图: 然后启 ...