BZOJ2178 圆的面积并 计算几何 辛普森积分
原文链接https://www.cnblogs.com/zhouzhendong/p/BZOJ2178.html
题目传送门 - BZOJ2178
题意
给出 $n(n\leq 1000)$ 个圆,求面积并。
所有圆的圆心坐标和半径都是绝对值不大于 1000 的整数。
题解
自适应辛普森积分模板题。注意先删掉被其他圆包含的圆。
但是 bzoj 大概是加过数据了,网上大部分直接自适应辛普森的代码都 TLE 了。
有一种卡常方法效果很好:
把 x 坐标按照整点划分成 $O(1000)$ 个区间,对于每一个区间,删除不涉及这个区间的所有圆。然后就过了。
代码
#include <bits/stdc++.h>
#define y1 __zzd12323
using namespace std;
const int N=1005;
const double Eps=1e-9,INF=1e9;
double sqr(double x){
return x*x;
}
int n;
struct Circle{
double x,y,r;
}c[N],_c[N];
bool cmpr(Circle a,Circle b){
return a.r>b.r;
}
struct Seg{
double L,R;
}s[N];
bool cmp(Seg a,Seg b){
return a.L<b.L;
}
double F(double x){
int m=0;
for (int i=1;i<=n;i++){
if (fabs(x-c[i].x)>c[i].r-Eps)
continue;
double M=c[i].y,a=sqrt(sqr(c[i].r)-sqr(x-c[i].x));
s[++m].L=M-a,s[m].R=M+a;
}
sort(s+1,s+m+1,cmp);
double res=0.0,mx=-INF;
for (int i=1;i<=m;i++)
if (s[i].L>mx)
res+=s[i].R-s[i].L,mx=s[i].R;
else if (s[i].R>mx)
res+=s[i].R-mx,mx=s[i].R;
return res;
}
double Simpson(double a,double b,double Fa,double Fb,double Fab){
return (b-a)/6*(Fa+Fab*4+Fb);
}
double Asr(double a,double b,double v,double Fa,double Fb,double Fab){
double ab=(a+b)/2;
double LFab=F((a+ab)/2),L=Simpson(a,ab,Fa,Fab,LFab);
double RFab=F((ab+b)/2),R=Simpson(ab,b,Fab,Fb,RFab);
if (fabs(v-L-R)<Eps)
return v;
return Asr(a,ab,L,Fa,Fab,LFab)
+Asr(ab,b,R,Fab,Fb,RFab);
}
int killed[N];
double Dis(double x1,double y1,double x2,double y2){
return sqrt(sqr(x1-x2)+sqr(y1-y2));
}
int main(){
scanf("%d",&n);
double a=INF,b=-INF;
for (int i=1;i<=n;i++){
scanf("%lf%lf%lf",&c[i].x,&c[i].y,&c[i].r);
a=min(a,c[i].x-c[i].r);
b=max(b,c[i].x+c[i].r);
}
sort(c+1,c+n+1,cmpr);
for (int i=1;i<=n;i++)
for (int j=i+1;j<=n;j++)
if (Dis(c[i].x,c[i].y,c[j].x,c[j].y)+c[j].r<c[i].r+Eps)
killed[j]=1;
int _n=0;
for (int i=1;i<=n;i++)
if (!killed[i])
c[++_n]=c[i];
n=_n;
double ans=0;
for (double x=a;x<b;x++){
for (int i=1;i<=n;i++)
_c[i]=c[i];
int _n=n;
n=0;
for (int i=1;i<=_n;i++)
if (c[i].x-c[i].r<i+1&&c[i].x+c[i].r>i)
c[++n]=_c[i];
n=_n;
for (int i=1;i<=n;i++)
c[i]=_c[i];
double Fa=F(x),Fb=F(x+1),Fab=F((x+x+1)/2);
ans+=Asr(x,x+1,Simpson(x,x+1,Fa,Fb,Fab),Fa,Fb,Fab);
}
printf("%.3lf",ans);
return 0;
}
BZOJ2178 圆的面积并 计算几何 辛普森积分的更多相关文章
- 【BZOJ2178】圆的面积并(辛普森积分)
[BZOJ2178]圆的面积并(辛普森积分) 题面 BZOJ 权限题 题解 把\(f(x)\)设为\(x\)和所有圆交的线段的并的和. 然后直接上自适应辛普森积分. 我精度死活一个点过不去,不要在意我 ...
- BZOJ2178 圆的面积并(simpson积分)
板子题.可以转一下坐标防止被卡.精度和常数实在难以平衡. #include<iostream> #include<cstdio> #include<cmath> # ...
- [SPOJ-CIRU]The area of the union of circles/[BZOJ2178]圆的面积并
[SPOJ-CIRU]The area of the union of circles/[BZOJ2178]圆的面积并 题目大意: 求\(n(n\le1000)\)个圆的面积并. 思路: 对于一个\( ...
- BZOJ2178: 圆的面积并(格林公式)
题面 传送门 题解 好神仙-- 先给几个定义 平面单连通区域:设\(D\)是平面内一区域,若属于\(D\)内任一简单闭曲线的内部都属于\(D\),则称\(D\)为单连通区域.通俗地说,单连通区域是没有 ...
- bzoj2178: 圆的面积并
Description 给出N个圆,求其面积并 Input 先给一个数字N ,N< = 1000 接下来是N行是圆的圆心,半径,其绝对值均为小于1000的整数 Output 面积并,保留三位小数 ...
- [BZOJ 2178] 圆的面积并 【Simpson积分】
题目链接:BZOJ - 2178 题目分析 用Simpson积分,将圆按照 x 坐标分成连续的一些段,分别用 Simpson 求. 注意:1)Eps要设成 1e-13 2)要去掉被其他圆包含的圆. ...
- bzoj 2178 圆的面积并【simpson积分】
直接套simpson,f可以直接把圆排序后扫一遍所有圆,这样维护一个区间就可以避免空段. 然而一定要去掉被其他圆完全覆盖的圆,否则会TLE #include<iostream> #incl ...
- BZOJ 2178: 圆的面积并 [辛普森积分 区间并]
2178: 圆的面积并 Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 1740 Solved: 450[Submit][Status][Discus ...
- bzoj 2178 圆的面积并 —— 辛普森积分
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2178 先看到这篇博客:https://www.cnblogs.com/heisenberg- ...
随机推荐
- mysql连表分组报错---- sql_mode=only_full_group_by问题解决
#### sql语句报错问题 #1055 - Expression #3 of SELECT list is not in GROUP BY clause and contains nonaggreg ...
- 【原创】大数据基础之Benchmark(1)HiBench
HiBench 7官方:https://github.com/intel-hadoop/HiBench 一 简介 HiBench is a big data benchmark suite that ...
- idea Unable to open debugger port (127.0.0.1:58006) Address already in use: JVM_Bind 的解决办法
报错说端口58006 被占用了,于是去修改端口 重新dubug 发现换个端口号还是不行,同样的错误.有时候你把idea关闭重新打开依旧不起作用.最暴力的办法就是重启电脑... 问题解决: 查看使用中的 ...
- Confluence 6 配置管理员会话安全的备注
禁用密码确定. Confluence 安装使用自定义授权机制有可能会在密码校验的时候遇到问题.如果必要的话,你可以设置 password.confirmation.disabled 系统属性来禁用密码 ...
- android 使用opencv
1.将已有的项目名称改名字,但一直报错 Error:A problem occurred configuring project ':app'.> executing external nati ...
- LeetCode(87):扰乱字符串
Hard! 题目描述: 给定一个字符串 s1,我们可以把它递归地分割成两个非空子字符串,从而将其表示为二叉树. 下图是字符串 s1 = "great" 的一种可能的表示形式. gr ...
- PDF怎么去除页眉页脚,PDF页眉页脚编辑方法
我们在使用文件的时候需要编辑页眉页脚的时候,这个时候我们应该怎么做呢,相信别的文件大家都知道怎么编辑了,PDF文件大家都知道吗,最开始接触这个文件的时候小编觉得很难,之后找到技巧之后也并没有很难,今天 ...
- 乘法原理,加法原理,多重集的排列数(多个系列操作穿插的排列数) 进阶指南 洛谷p4778
https://www.luogu.org/problemnew/solution/P4778 非常好的题目,囊括了乘法加法原理和多重集合排列,虽然最后使用一个结论解出来的.. 给定一个n的排列,用最 ...
- 一道面试题 vuex缺点?
最近去面试的时候,面试官有一道题是让我阐述用vuex的优缺点,优点倒还好说,这个缺点还真没有认识到,有道友可以帮忙解惑嘛? 2 回答 慕标5265247 这种问题一般都有通用回答套路.一件挺好的东西, ...
- MySQL基于ROW格式的数据恢复
大家都知道MySQL Binlog 有三种格式,分别是Statement.Row.Mixd.Statement记录了用户执行的原始SQL,而Row则是记录了行的修改情况,在MySQL 5.6以上的版本 ...