[日常摸鱼]bzoj1502[NOI2005]月下柠檬树-简单几何+Simpson法
关于自适应Simpson法的介绍可以去看我的另一篇blog
http://www.lydsy.com/JudgeOnline/problem.php?id=1502
题意:空间里圆心在同一直线上且底面与地面平行的若干个圆台和顶层的圆锥以$\alpha$的角度投影到地面,求投影的面积。
(其实我是看po姐博客来的x)
首先把圆锥的顶点也看成一个半径为0的圆锥,对于每个高度为$h$的圆投影下去的坐标是$h/tan(\alpha)$,半径不变,而对于圆台的侧面投影下去是上下底两个圆的切线。

关于两个圆的切线可以像图上这样求(参考po姐博客的x)
$\sin(\alpha)=\frac{r_{i-1}-r_i}{x_i-x_{i-1}}$
这个式子同样可以适用于其他情况,然后三角函数搞一下求出其他点的坐标,根据坐标的范围用Simpson法来求面积。
只是把求点的函数值改成扫一遍所有的点和圆,找最大值。
哦然后我的Simpson递归的时候本来是让eps乘上$\frac{1}{2}$的…但是这样会T掉,不乘又会wa…orz
然后改成$\frac{2}{3}$就可以了…跑900+ms真神奇
#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=515;
struct point
{
double x,y;
};
struct line
{
point p1,p2;
double k,b;
line(){}
void modify(double x1,double y1,double x2,double y2)
{
p1.x=x1;p1.y=y1;
p2.x=x2;p2.y=y2;
k=(p1.y-p2.y)/(p1.x-p2.x);
b=p1.y-k*p1.x;
}
double f(double x)
{
return k*x+b;
}
}ls[N];
struct circle
{
double x,r;
}cs[N];
int n,tot;double alpha;
inline double f(double x)
{
double res=0;double eps=1e-6;
for(register int i=1;i<=n;i++)
{
double dis=fabs(x-cs[i].x);
if(dis-cs[i].r>-eps)continue;
double y=sqrt(cs[i].r*cs[i].r-dis*dis);
res=max(res,y);
}
for(register int i=1;i<=tot;i++)
{
if(!(ls[i].p1.x<=x&&x<=ls[i].p2.x))continue;
double y=ls[i].f(x);
res=max(res,y);
}
return res;
}
inline double calc(double l,double r)
{
double mid=l+(r-l)/2;
return (f(l)+4.0*f(mid)+f(r))*(r-l)/6.0;
}
inline double asr(double l,double r,double area,double eps)
{
double mid=l+(r-l)/2;
double L=calc(l,mid),R=calc(mid,r);
if(fabs(L+R-area)<=eps*10.0)return L+R+(L+R-area)/10.0;
return asr(l,mid,L,eps*2.0/3.0)+asr(mid,r,R,eps*2.0/3.0);
}
inline double solve(double l,double r,double eps)
{
return asr(l,r,calc(l,r),eps);
}
int main()
{
//freopen("input.in","r",stdin);
double eps=1e-6,l,r;l=r=0;
scanf("%d%lf",&n,&alpha);alpha=1/(tan(alpha));
for(register int i=1;i<=n+1;i++)
{
scanf("%lf",&cs[i].x);
cs[i].x*=alpha;
cs[i].x+=cs[i-1].x;
}
for(register int i=1;i<=n;i++)
{
scanf("%lf",&cs[i].r);
}
for(register int i=1;i<=n+1;i++)
{
l=min(l,cs[i].x-cs[i].r);
r=max(r,cs[i].x+cs[i].r);
}
for(register int i=2;i<=n+1;i++)
{
double L=cs[i].x-cs[i-1].x;
if(L-fabs(cs[i].r-cs[i-1].r)<eps)continue;
//double sin_alpha=fabs(cs[i].r-cs[i-1].r)/L;
double sin_alpha=(cs[i-1].r-cs[i].r)/L;
double cos_alpha=sqrt(1-sin_alpha*sin_alpha);
ls[++tot].modify(cs[i-1].x+cs[i-1].r*sin_alpha,cs[i-1].r*cos_alpha,
cs[i].x+cs[i].r*sin_alpha,cs[i].r*cos_alpha);
}
printf("%.2lf",solve(l,r,eps)*2.0);
return 0;
}
[日常摸鱼]bzoj1502[NOI2005]月下柠檬树-简单几何+Simpson法的更多相关文章
- 【BZOJ-1502】月下柠檬树 计算几何 + 自适应Simpson积分
1502: [NOI2005]月下柠檬树 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1017 Solved: 562[Submit][Status] ...
- [NOI2005]月下柠檬树[计算几何(simpson)]
1502: [NOI2005]月下柠檬树 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1169 Solved: 626[Submit][Status] ...
- BZOJ1502: [NOI2005]月下柠檬树
Simpson法相当好用啊!神奇的骗分算法! /************************************************************** Problem: 1502 ...
- 【BZOJ1502】[NOI2005]月下柠檬树 Simpson积分
[BZOJ1502][NOI2005]月下柠檬树 Description 李哲非常非常喜欢柠檬树,特别是在静静的夜晚,当天空中有一弯明月温柔地照亮地面上的景物时,他必会悠闲地坐在他亲手植下的那棵柠檬树 ...
- BZOJ 1502: [NOI2005]月下柠檬树 [辛普森积分 解析几何 圆]
1502: [NOI2005]月下柠檬树 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1070 Solved: 596[Submit][Status] ...
- [NOI2005]月下柠檬树
题意 F.A.Qs Home Discuss ProblemSet Status Ranklist Contest 入门OJ ModifyUser autoint Logout 捐赠本站 Probl ...
- 5.21 省选模拟赛 luogu P4207 [NOI2005]月下柠檬树 解析几何 自适应辛普森积分法
LINK:月下柠檬树 之前感觉这道题很鬼畜 实际上 也就想到辛普森积分后就很好做了. 辛普森积分法的式子不再赘述 网上多的是.值得一提的是 这道题利用辛普森积分法的话就是一个解析几何的问题 而并非计算 ...
- 【bzoj1502】[NOI2005]月下柠檬树 自适应Simpson积分
题目描述 李哲非常非常喜欢柠檬树,特别是在静静的夜晚,当天空中有一弯明月温柔地照亮地面上的景物时,他必会悠闲地坐在他亲手植下的那棵柠檬树旁,独自思索着人生的哲理.李哲是一个喜爱思考的孩子,当他看到在月 ...
- BZOJ1502:[NOI2005]月下柠檬树——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=1502 https://www.luogu.org/problemnew/show/P4207 李哲 ...
随机推荐
- Codeforces1009F Dominant Indices
dsu on tree 题目链接 点我跳转 题目大意 给定一棵以 \(1\) 为根,\(n\) 个节点的树.设\(d(u,x)\) 为 \(u\) 子树中到 \(u\) 距离为 \(x\) 的节点数. ...
- 轻松将CAD文件转为加密的PDF文件
对于从事设计相关工作的朋友来说,CAD肯定再熟悉不过了.一些有特殊要求的CAD文件,需要将其转换成为PDF文件以方便保存.传输.打印,同时还得保证设计图稿的安全性,所以将CAD文件直接转为加密的PDF ...
- 紧急发布用cherry-pick检出当前分支所有我的提交记录
目录 背景 操作命令 cherry-pick git log Shell脚本 背景 公司接了个新项目,需在平台上增加几个新接口,问题是本来说是和平台一起迭代发布的时间提前了,但当前的代码都和其他开发人 ...
- 慢SQL优化:where id in (select max(id)...) 改为join后性能提升400倍
背景 有两张表,都是主键递增,类似于主表和明细表: statistics_apply:统计申请表,主键applyId,7万多条记录 statistics_apply_progress:统计申请进度表( ...
- Contest 982
A 直接模拟即可,为了方便边界判断建议用 !=. 时间复杂度 \(O\left(n\right)\). B \(w\) 排序来处理内向者,坐人后丢进大根堆来处理外向者. 时间复杂度 \(O\left( ...
- IDEA集成Docker插件后出现日志乱码的解决办法
修改IDEA的vmoptions文件 找到IDEA安装目录的bin目录,在idea.exe.vmoptions和idea64.exe.vmoptions文件中追加以下内容: -Dfile.encodi ...
- 那么多人学习C++,学习它有什么好处?学完以后能从事哪些岗位?
相信很多人接触编程都是源于大学期间的那堂C++语言程序编程,但是这门课却只告诉了你编程语言是什么,却没告诉你要怎么去熟练掌握编程.所以,不可避免的是许多人在毕业前夕才发现虽然学会了C++,但是好像却不 ...
- jstack测试
1.RUNABLE 2.BLOCKED 3.WAITING/TIMED_WAITING Reference Handler线程与Finalizer线程,这两个线程用于虚拟机处理override了obj ...
- Clickhouse 入门
clickhouse 简介 ck是一个列式存储的数据库,其针对的场景是OLAP.OLAP的特点是: 数据不经常写,即便写也是批量写.不像OLTP是一条一条写 大多数是读请求 查询并发较少,不适合放置先 ...
- 【2020.11.28提高组模拟】T1染色(color)
[2020.11.28提高组模拟]T1染色(color) 题目 题目描述 给定 \(n\),你现在需要给整数 \(1\) 到 \(n\) 进行染色,使得对于所有的 \(1\leq i<j\leq ...