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

Input
Output
输出1个实数,表示树影的面积。四舍五入保留两位小数。
Sample Input
10.0 10.00 10.00
4.00 5.00
Sample Output
题解:简洁题意就是让你求一堆圆和梯形的面积交。
Simpson积分:
相当于用一个3次函数去拟合所求的图形,可以用于任意连续不规则图形,但是误差很大。自适应simpson积分呢,就是再对f(l,mid)和f(mid,r)分别算一下。如果f(l,mid)+f(mid,r)与f(l,r)误差很小,则直接返回f(l,r),否则继续递归计算。这样误差就比较小了(虽说也可以卡)。
剩下的问题就是如何求两圆的公切线。比较容易的方法是设两圆半径为R,r,先令R'=R-r,r'=0,这样就把第二个圆缩成了一个点,变成求点与圆的切线,再平移回去即可。
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <iostream>
#define pi acos(-1.0)
using namespace std;
typedef double db;
const db eps=1e-6;
int n,m;
db alpha,h[510],O[510],R[510],ax[510],ay[510],bx[510],by[510];
inline db f(db x)
{
db ret=0;
int i;
for(i=1;i<=n;i++) if(x>=O[i]-R[i]&&x<=O[i]+R[i])
ret=max(ret,sqrt(R[i]*R[i]-(O[i]-x)*(O[i]-x)));
for(i=1;i<=m;i++) if(x>=ax[i]&&x<=bx[i])
ret=max(ret,ay[i]+(by[i]-ay[i])*(x-ax[i])/(bx[i]-ax[i]));
return ret;
}
inline db simpson(db a,db b)
{
return (b-a)/6*(f(a)+f(b)+f((a+b)/2)*4);
}
inline db calc(db l,db r,db val)
{
db mid=(l+r)/2,a=simpson(l,mid),b=simpson(mid,r);
if(fabs(a+b-val)<eps) return val;
return calc(l,mid,a)+calc(mid,r,b);
}
int main()
{
scanf("%d%lf",&n,&alpha);
int i;
db l=1e9,r=-1e9;
for(i=0;i<=n;i++)
{
scanf("%lf",&h[i]),h[i]/=tan(alpha);
if(i) h[i]+=h[i-1];
}
for(i=1;i<=n;i++)
{
scanf("%lf",&R[i]),O[i]=h[i-1],l=min(l,O[i]-R[i]),r=max(r,O[i]+R[i]);
if(i!=1&&O[i]-O[i-1]>fabs(R[i]-R[i-1]))
{
db a=(R[i-1]-R[i])/(O[i]-O[i-1]),b=sqrt(1-a*a);
ax[++m]=O[i-1]+a*R[i-1],ay[m]=b*R[i-1];
bx[m]=O[i]+a*R[i],by[m]=b*R[i];
}
}
if(h[n]>O[n]+R[n])
{
db a=R[n]/(h[n]-O[n]),b=sqrt(1-a*a);
r=h[n];
ax[++m]=O[n]+a*R[n],ay[m]=b*R[n];
bx[m]=h[n],by[m]=0;
}
printf("%.2lf",calc(l,r,simpson(l,r))*2);
return 0;
}//2 0.7853981633 10.0 10.00 10.00 4.00 5.00
【BZOJ1502】[NOI2005]月下柠檬树 Simpson积分的更多相关文章
- BZOJ 1502: [NOI2005]月下柠檬树 [辛普森积分 解析几何 圆]
1502: [NOI2005]月下柠檬树 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1070 Solved: 596[Submit][Status] ...
- [NOI2005]月下柠檬树(计算几何+积分)
题目描述 李哲非常非常喜欢柠檬树,特别是在静静的夜晚,当天空中有一弯明月温柔 地照亮地面上的景物时,他必会悠闲地坐在他亲手植下的那棵柠檬树旁,独自思 索着人生的哲理. 李哲是一个喜爱思考的孩子,当他看 ...
- 【BZOJ1502】【NOI2005】月下柠檬树 simpson 积分
特别提醒:eps至少要5e-6 首先我们来研究下平行光对投影的影响. 一个二维的图形,若它与光屏平行,那么不论平行光与光屏的夹角为多少,所得图形与原图形全等的(只是位置会有影响) 通过这么一分析,我们 ...
- [日常摸鱼]bzoj1502[NOI2005]月下柠檬树-简单几何+Simpson法
关于自适应Simpson法的介绍可以去看我的另一篇blog http://www.lydsy.com/JudgeOnline/problem.php?id=1502 题意:空间里圆心在同一直线上且底面 ...
- BZOJ 1502 月下柠檬树(simpson积分)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1502 题意:给出如下一棵分层的树,给出每层的高度和每个面的半径.光线是平行的,与地面夹角 ...
- BZOJ1502: [NOI2005]月下柠檬树
Simpson法相当好用啊!神奇的骗分算法! /************************************************************** Problem: 1502 ...
- 【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] ...
- [NOI2005]月下柠檬树
题意 F.A.Qs Home Discuss ProblemSet Status Ranklist Contest 入门OJ ModifyUser autoint Logout 捐赠本站 Probl ...
随机推荐
- Thinkphp5笔记二:创建模块
系统:window 7 64位 Thinkphp版本:5.0.5 环境:wampserver集成 我的项目是部署在本地www/thinkphp 目录下.在做之前,先要考虑清楚,你需要几个模块来完成你 ...
- Java初学者必学的JSTL
所谓JSTL就是标签库 JSP Standard Tag Library,如果做为java初学者你看不懂那些$符号的话,就有必要来了解一下JSTL,如果你看到满眼的<%}%>(Scrip ...
- mongoose实现批量删除和多id查询的api/方法
删除一条数据:传入id Model.remove({ _id: 传入的id }); 删除多条数据,传入id数组,使用$in方法 Model.remove({ _id: { $in: ['aID', ' ...
- JavaBridge
有的时候我们需要在PHP里调用JAVA平台封装好的jar包里的class类和方法 一般的做法是采用php-java-bridge做桥接 1.实现原理: 先打开java的一个监听端口,php调用java ...
- windows 下为Python安装redis
最近在看<redis实战>,里面的redis示例都是Python写的,先将环境整好 启动redis redis-server.exe redis.conf 安装了python2.7 安装 ...
- Servlet3简介
servlet基础知识:http://blog.csdn.net/chjttony/article/details/6086292 ServletContext相关知识:http://blog.csd ...
- linux环境中,如何通过手动创建crontab文件的方式来设置crontab定时调度任务?
需求描述: 之前在创建定时任务的时候,都是通过cronab -e的方式进行创建,今天在做通过脚本部署定时任务的时候, 就想,通过crontab -e编辑的定时任务存放在哪个文件里,是否,可以手动的编辑 ...
- Java从控制台接受输入字符
创建一个类,在该类的主方法中创建Scanner扫描起来封装System类的in输入流,然后提示用户输入身份证号码,并输入身份证号码的位数. 代码如下: import java.util.Scanner ...
- dubbo开发前戏--ZooKeeper集群部署(3.4.6)
最近在开发dubbo服务的时候一直用的是公司提供的zk平台,因为使用的人太多或者没人维护老是出问题,导致dubbo服务偶尔可以调通,偶尔调不通的情况,所以花点时间自己部署一套,后面出问题还方便看日志排 ...
- 基于端口的弱口令检测工具--iscan
亲手打造了一款弱口令检测工具,用Python编写,主要可以用于内网渗透.弱口令检测等方面,目前集成了常见端口服务,包含 系统弱口令:ftp.ssh.telnet.ipc$ 数据库弱口令:mssql.m ...