1502: [NOI2005]月下柠檬树

Time Limit: 5 Sec  Memory Limit: 64 MB
Submit: 1169  Solved: 626
[Submit][Status][Discuss]

Description

Input

文件的第1行包含一个整数n和一个实数alpha,表示柠檬树的层数和月亮的光线与地面夹角(单位为弧度)。第2行包含n+1个实数h0,h1,h2,…,hn,表示树离地的高度和每层的高度。第3行包含n个实数r1,r2,…,rn,表示柠檬树每层下底面的圆的半径。上述输入文件中的数据,同一行相邻的两个数之间用一个空格分隔。输入的所有实数的小数点后可能包含1至10位有效数字。

Output

输出1个实数,表示树影的面积。四舍五入保留两位小数。

Sample Input

2 0.7853981633
10.0 10.00 10.00
4.00 5.00

Sample Output

171.97

HINT

1≤n≤500,0.3

Source

求一棵树(圆锥加圆台组成)在平面上的投影的面积。

给定投影角度(0.3 < alpha <= pi/2)。

先来想想圆的投影是什么样子

还是他自己。

再想圆锥投影是什么样子

一个点加一个圆,并且有这个点与该圆的两条切线(该点在圆内部时没有切线)

再想圆台

两个圆,加上两个圆的外公切线组成的一坨图形。

不妨随意画一个。

好难画- -!

大概就转化成这个样子了。

观察这个图形…

轴对称啊- -!

首先AC长是圆心距,可求。

AI长是半径差,可求。

所以CI可求。

连接FC,观察△FAC

2*S△FAC=FG*AC=CI*AF

AF为半径,已知。

所以FG可求。

于是AG可求。

A点坐标已知,所以F点坐标已知。

E点,直接相似即可。

或者用射影定理求EF

概述图中,在Rt△ABC中,∠ABC=90°,BD是斜边AC上的高,则有射影定理如下:
BD²=AD·CD
AB²=AC·AD
BC²=CD·AC
#include<cmath>
#include<cstdio>
#include<algorithm>
#define pf(x) ((x)*(x))
using namespace std;
const int N=+;
const double eps=1e-;
typedef pair<double,double> point;
typedef pair<double,double> circle;
struct line{
point s,t;
double k,b;
line(){}
line(point _s,point _t){
s=_s;t=_t;
k=(s.second-t.second)/(s.first-t.first);
b=s.second-s.first*k;
}
const double f(const double x){
return k*x+b;
}
};
int n,n1;double alpha,H[N];
point p;line L[N];circle C[N];
double lb=2e9,rb;
double sina,cosa,tana;
inline void add(const circle &a,const circle &b){
n1++;
sina=(a.second-b.second)/(b.first-a.first);
cosa=sqrt(-pf(sina));
tana=sina/cosa;
L[n1].s=make_pair(a.first+a.second*sina,a.second*cosa);
L[n1].t=make_pair(b.first+b.second*sina,b.second*cosa);
L[n1].k=-tana;
L[n1].b=L[n1].s.second-L[n1].s.first*L[n1].k;
}
inline const double F(const double x){
double re=;
for(int i=;i<=n1;i++) if(x>=L[i].s.first&&x<=L[i].t.first) re=max(re,L[i].f(x));
for(int i=;i<=n;i++) if(x>=C[i].first-C[i].second&&x<=C[i].first+C[i].second) re=max(re,sqrt(pf(C[i].second)-pf(x-C[i].first)));
return re;
}
inline const double simpson(const double l,const double r){
double mid=(l+r)/;
return (F(l)+F(r)+*F(mid))*(r-l)/;
}
inline double asr(double l,double r,double eps,double last){
double mid=(l+r)/;
double L=simpson(l,mid),R=simpson(mid,r);
if(fabs(L+R-last)<=*eps) return L+R+(L+R-last)/;
return asr(l,mid,eps/,L)+asr(mid,r,eps/,R);
}
inline int cmp(const double x){
if(fabs(x)<eps) return ;
return x>?:-;
}
int main(){
scanf("%d%lf",&n,&alpha);
for(int i=;i<=n+;i++) scanf("%lf",&H[i]),H[i]+=H[i-];
for(int i=;i<=n;i++) scanf("%lf",&C[i].second);
double ta=tan(alpha);
p=make_pair(H[n+]/ta,);rb=max(rb,p.first);
double x,r,l,h;
C[n].first=H[n]/ta;
x=C[n].first;r=C[n].second;
lb=min(lb,x-r);
rb=max(rb,x+r);
if(x+r<p.first){
l=pf(r)/(p.first-x);// 射影定理
h=sqrt(pf(r)-pf(l));
L[++n1]=line(make_pair(x+l,h),p);
}
for(int i=n-;i;i--){
C[i].first=H[i]/ta;
x=C[i].first;r=C[i].second;
lb=min(lb,x-r);
rb=max(rb,x+r);
if(cmp(C[i+].first-x-fabs(C[i+].second-r))>)//内含
add(C[i],C[i+]);
}
printf("%.2lf\n",*asr(lb,rb,eps,simpson(lb,rb)));
return ;
}
 

[NOI2005]月下柠檬树[计算几何(simpson)]的更多相关文章

  1. [NOI2005]月下柠檬树(计算几何+积分)

    题目描述 李哲非常非常喜欢柠檬树,特别是在静静的夜晚,当天空中有一弯明月温柔 地照亮地面上的景物时,他必会悠闲地坐在他亲手植下的那棵柠檬树旁,独自思 索着人生的哲理. 李哲是一个喜爱思考的孩子,当他看 ...

  2. 【bzoj1502】[NOI2005]月下柠檬树 自适应Simpson积分

    题目描述 李哲非常非常喜欢柠檬树,特别是在静静的夜晚,当天空中有一弯明月温柔地照亮地面上的景物时,他必会悠闲地坐在他亲手植下的那棵柠檬树旁,独自思索着人生的哲理.李哲是一个喜爱思考的孩子,当他看到在月 ...

  3. [BZOJ 1502] [NOI2005] 月下柠檬树 【Simpson积分】

    题目链接: BZOJ - 1502 题目分析 这是我做的第一道 Simpson 积分的题目.Simpson 积分是一种用 (fl + 4*fmid + fr) / 6 * (r - l) 来拟合 fl ...

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

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

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

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

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

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

  7. [NOI2005]月下柠檬树

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

  8. 5.21 省选模拟赛 luogu P4207 [NOI2005]月下柠檬树 解析几何 自适应辛普森积分法

    LINK:月下柠檬树 之前感觉这道题很鬼畜 实际上 也就想到辛普森积分后就很好做了. 辛普森积分法的式子不再赘述 网上多的是.值得一提的是 这道题利用辛普森积分法的话就是一个解析几何的问题 而并非计算 ...

  9. BZOJ1502:[NOI2005]月下柠檬树——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=1502 https://www.luogu.org/problemnew/show/P4207 李哲 ...

随机推荐

  1. 10.6 监控io性能 10.7 free命令 10.8 ps命令 10.9 查看网络状态 10.10 linux下抓包

    iostat sysstat 包里面包括 sar 和 iostat [root@centos7 ~]# iostat Linux 3.10.0-693.2.2.el7.x86_64 (centos7. ...

  2. Mac OS X 下安装MySQL 5.7

    下载安装包 官网下载安装包 选择相应的版本和格式,有 .dmg 和压缩包两种. 这里选择简单直接的 .dmg安装包,下载的时候可以将下载地址直接贴到迅雷,速度比较快. 安装 安装很简单,直接双击下好的 ...

  3. [转]jmeter实战

    [转]http://blog.csdn.net/ultrani/article/details/8309932 本文主要介绍性能测试中的常用工具jmeter的使用方式,以方便开发人员在自测过程中就能自 ...

  4. 【machine translate】deep learning seq2seq

    https://www.tensorflow.org/tutorials/seq2seq https://medium.com/@devnag/seq2seq-the-clown-car-of-dee ...

  5. Android开发学习笔记-自定义TextView属性模版

    如果项目中有很多个控件使用的是同一种样式,则为了方便,可以将样式设置到系统中去,这样使用的时候会方便很多. 下面是自定义样式模版的方法. 1.在style.xml文件中添加自己要设置的样式内容 < ...

  6. webGL 光照

    1.着色(shading) 在三维图形学术语“着色”的真正含义就是,根据光照条件重建“物体各表面明暗不一的效果”的过程.明白着色过程,需要考虑两件事:    1.发出光线的光源类型.    2.物体表 ...

  7. 未定义变量 "caffe" 或类 "caffe.reset_all"

    配置caffe后在matlab中测试报错. 未定义变量 "caffe" 或类 "caffe.reset_all". 我的原因是:caffe在matlab接口处没 ...

  8. js九九乘法表的应用

    <html> <head> <meta charset=utf-8" /> <title>js九九乘法表</title> < ...

  9. phpcms v9 get的强大之处(列表页调用点击数)

    {pc:get sql="select * from v9_art as g left join v9_art_data as p on p.id=g.id and g.catid=12 o ...

  10. PHP mysql经典问题,防止库存把控不足问题

    在目前这家公司做的第一个项目抽奖项目,要求每人每天可以有20次抽奖机会,抽奖机会可以通过多种方式获取,那么就要求每次入库增加抽奖机会的时候检测当前拥有的抽奖机会是否达到了20次,如果达到了,就不再增加 ...