F Girlfriend (阿波罗尼斯球+简单几何)

题目大意:
给定四个点,每两个点构成一个阿波罗尼斯球,求两圆相交部分的体积。
思路:
一看就是几何题啊,话不多说直接开淦。。。
首先对于阿波罗尼斯球的性质得到 ∣ P A ∣ = = K ∗ ∣ P B ∣ |PA| == K*|PB| ∣PA∣==K∗∣PB∣
假设 A ( x 0 , y 0 , z 0 ) A(x_0,y_0,z_0) A(x0​,y0​,z0​), B ( x 1 , y 1 , z 1 ) B(x_1,y_1,z_1) B(x1​,y1​,z1​)那么我们有:

( x − x 0 ) 2 + ( y − y 0 ) 2 + ( z − z 0 ) 2 = k ∗ k ∗ ( ( x − x 1 ) 2 + ( y − y 1 ) 2 + ( z − z 1 ) 2 ) (x-x_0)^2+(y-y_0)^2+(z-z_0)^2=k*k*((x-x_1)^2+(y-y_1)^2+(z-z_1)^2) (x−x0​)2+(y−y0​)2+(z−z0​)2=k∗k∗((x−x1​)2+(y−y1​)2+(z−z1​)2)

整理得:

( 1 − k 2 ) ∗ x 2 + ( 1 − k 2 ) ∗ y 2 + ( 1 − k 2 ) ∗ z 2 + ( 2 ∗ k 2 ∗ x 1 − 2 ∗ x 0 ) ∗ x + ( 2 ∗ k 2 ∗ y 1 − 2 ∗ y 0 ) ∗ y + ( 2 ∗ k 2 ∗ z 1 − 2 ∗ z 0 ) ∗ z + x 0 2 + y 0 2 + z 0 2 − k 2 ( x 1 2 + y 1 2 + z 1 2 ) = 0 (1-k^2)*x^2+(1-k^2)*y^2+(1-k^2)*z^2+(2*k^2*x_1-2*x_0)*x+(2*k^2*y_1-2*y_0)*y+(2*k^2*z_1-2*z_0)*z+x_0^2+y_0^2+z_0^2-k^2(x_1^2+y_1^2+z_1^2) = 0 (1−k2)∗x2+(1−k2)∗y2+(1−k2)∗z2+(2∗k2∗x1​−2∗x0​)∗x+(2∗k2∗y1​−2∗y0​)∗y+(2∗k2∗z1​−2∗z0​)∗z+x02​+y02​+z02​−k2(x12​+y12​+z12​)=0

由一般球的展开式可得:
x 2 + y 2 + z 2 + 2 a x + 2 b y + 2 c z + d = 0 x^2+y^2+z^2+2ax+2by+2cz+d=0 x2+y2+z2+2ax+2by+2cz+d=0
整理得:
( x + a ) 2 + ( y + b ) 2 + ( z + c ) 2 = a 2 + b 2 + c 2 − d (x+a)^2+(y + b)^2+(z + c)^2=a^2+b^2+c^2-d (x+a)2+(y+b)2+(z+c)2=a2+b2+c2−d
自此,我们其实做完了第一步准备工作,也就是求出固定k值球的半径。
r = a 2 + b 2 + c 2 − d r=\sqrt {a^2+b^2+c^2-d} r=a2+b2+c2−d ​
接下来我们要判断两球的位置,对于相离,内切,内含的情况,我们可以非常容易的求出其相交的体积,对于相交情况我们需要一个结论。
我们将两个球分开来看

对于这个球,我们要求 ∣ j k ∣ |jk| ∣jk∣以上部分的体积
(一)
由三重积分先面后线可得:
V = ∫ r − h r π ∗ y 2 d z V=\int_{r-h}^r{π*y^2dz} V=∫r−hr​π∗y2dz
而 z 2 + y 2 = r 2 z^2+y^2=r^2 z2+y2=r2
所以有 V = ∫ r − h r π ∗ ( r 2 − z 2 ) d y V=\int_{r-h}^r{π*(r^2-z^2)dy} V=∫r−hr​π∗(r2−z2)dy

V = π h 2 ( r − h / 3 ) V = πh^2(r-h/3) V=πh2(r−h/3)
(二)
可以由二重积分推导:
V = ∬ R 2 − x 2 − y 2 − ( R − h ) d x d y V=\iint\sqrt{R^2-x^2-y^2}-(R-h)dxdy V=∬R2−x2−y2 ​−(R−h)dxdy
利用极坐标形式进行代换:
V = ∫ 0 2 π d θ ∫ 0 2 R h − h 2 ( R 2 − ρ 2 − ( R − h ) ) ρ d ρ V=\int_{0}^{2π}dθ\int_{0}^{\sqrt{2Rh-h^2}}(\sqrt{R^2-ρ^2}-(R-h))ρdρ V=∫02π​dθ∫02Rh−h2 ​​(R2−ρ2 ​−(R−h))ρdρ
整理上式也可得到相同结果。

至此所有的公式我们都已经推导出来,一一计算输出即可。

#include<iostream>
#include<algorithm>
#include<cstring>
#include<string>
#include<map>
#include<cstdio>
#include<cmath>
#include<iomanip>
#include<queue>
#define pi 3.1415926535
using namespace std;
typedef long long ll;
const int mod = 1e9 + 7;
typedef pair<int, int> pii;
const int N = 1e6 + 10;
void volume(double r1x, double r1y, double r1z, double r2x, double r2y, double r2z, double r1, double r2) {double d = sqrt((r1x - r2x) * (r1x - r2x) + (r1y - r2y) * (r1y - r2y) + (r1z - r2z) * (r1z - r2z));if (d >= r1 + r2) {printf("%.3lf\n", 0);}else if (d + r2 <= r1) {printf("%.3lf\n", 4 * 1.0 / 3 * 1.0 * pi * r2 * r2 * r2);}else if (d + r1 <= r2) {printf("%.3lf\n", 4 * 1.0 / 3 * 1.0 * pi * r1 * r1 * r1);}else {double ans = 0;double cosa = (r1 * r1 + d * d - r2 * r2) / (2.0 * r1 * d);double h1 = r1 - r1 * cosa;ans += pi * h1 * h1 * (r1 - h1 / 3.0);double cosb = (r2 * r2 + d * d - r1 * r1) / (2.0 * r2 * d);double h2 = r2 - r2 * cosb;ans += pi * h2 * h2 * (r2 - h2 / 3.0);printf("%.3lf\n", ans);}
}
int main() {double x[5], y[5], z[5];int t;cin >> t;while (t--){for (int i = 1; i <= 4; i++) {cin >> x[i] >> y[i] >> z[i];}double k1, k2;cin >> k1 >> k2;double dishu1 = 1 - k1 * k1;double a1 = (k1 * k1 * x[2] - x[1]) / dishu1, b1 = (k1 * k1 * y[2] - y[1]) / dishu1, c1 = (k1 * k1 * z[2] - z[1]) / dishu1;double d1 = ((x[1] * x[1] + y[1] * y[1] + z[1] * z[1]) - (k1 * k1 * (x[2] * x[2] + y[2] * y[2] + z[2] * z[2]))) / dishu1;double r1 = sqrt(a1 * a1 + b1 * b1 + c1 * c1 - d1);double dishu2 = 1 - k2 * k2;double a2 = (k2 * k2 * x[4] - x[3]) / dishu2, b2 = (k2 * k2 * y[4] - y[3]) / dishu2, c2 = (k2 * k2 * z[4] - z[3]) / dishu2;double d2 = ((x[3] * x[3] + y[3] * y[3] + z[3] * z[3]) - (k2 * k2 * (x[4] * x[4] + y[4] * y[4] + z[4] * z[4]))) / dishu2;double r2 = sqrt(a2 * a2 + b2 * b2 + c2 * c2 - d2);volume(a1, b1, c1, a2, b2, c2, r1, r2);}
}

2021牛客暑期多校训练营2 F Girlfriend (阿波罗尼斯圆+简单几何)相关推荐

  1. 2021牛客暑期多校训练营2 - F - Girlfriend ( 球体积相交 )

    题目连接:点击进入 题目 题意 A.B.C.D.k1.k2 已知,根据不等式, P1 的取值会形成一个图形,P2 类似,求两个图形的交 思路 这个式子取等号是阿波罗尼斯圆,二维平面是圆,三维是球壳,取 ...

  2. 2021牛客暑期多校训练营7

    2021牛客暑期多校训练营7 文章目录 2021牛客暑期多校训练营7 F:xay_loves_trees 解释 代码 H:xay_loves_count 解释 代码 I:xay_loves_or 解释 ...

  3. 2021牛客暑期多校训练营9

    2021牛客暑期多校训练营9 题号 题目 知识点 A A Math Challenge B Best Subgraph C Cells D Divide-and-conquer on Tree E E ...

  4. 2021牛客暑期多校训练营5

    2021牛客暑期多校训练营5 题号 题目 知识点 A Away from College B Boxes 概率 C Cheating and Stealing D Double Strings 线性d ...

  5. 2021牛客暑期多校训练营4

    2021牛客暑期多校训练营4 题号 题目 知识点 A Course B Sample Game C LCS D Rebuild Tree E Tree Xor 思维+线段树 F Just a joke ...

  6. 2021牛客暑期多校训练营3

    2021牛客暑期多校训练营3 题号 题目 知识点 A Guess and lies B Black and white C Minimum grid 二分图匹配 D Count E Math 数论+打 ...

  7. 2021牛客暑期多校训练营2

    2021牛客暑期多校训练营2 题号 题目 知识点 A Arithmetic Progression B Cannon C Draw Grids D Er Ba Game E Gas Station F ...

  8. 2021牛客暑期多校训练营1

    2021牛客暑期多校训练营1 题号 题目 知识点 难度 A Alice and Bob 博弈论 B Ball Dropping 计算几何 签到 C Cut the Tree D Determine t ...

  9. 2021牛客暑期多校训练营2,签到题CDFKI

    2021牛客暑期多校训练营2 题号 标题 已通过代码 通过率 团队的状态 A Arithmetic Progression 点击查看 6/72 未通过 B Cannon 点击查看 34/104 未通过 ...

最新文章

  1. R语言ggplot2可视化时间序列数据:ggplot2可视化在时间轴上添加按月的箱图(boxplot)
  2. linux命令tar
  3. 使用 AngularJS NodeJS 实现基于token 的认证应用(转)
  4. 使用Picasso实现图片圆角和图片圆形
  5. 【java】Java异常处理总结
  6. 怎么给自己的python换源_windows/linux下如何更换Python的pip源
  7. [转].NET 开源项目 Polly 介绍
  8. centos8 kernel source 安装_什么?你在物理机上安装Oracle总失败?那就试试Docker吧
  9. oracle pl/sql 基础
  10. 安装操作系统的过程图解
  11. 手把手FFmpeg入门——视频解码+解封装
  12. c++ log函数_第18节 函数的形参和实参-Web前端开发之Javascript-王唯
  13. 计算机旅游网站论文,设计一个旅游网站 计算机专业毕业论文.doc
  14. python爬虫之爬取拉勾网
  15. 天干地支计算公式_求天干地支的计算方法,
  16. 10G Ethernet Mac IP核
  17. 老年旅游行业解析:媒体矩阵布局到业务板块梳理
  18. 基于Crawler4j的WEB爬虫
  19. 室内定位解决方案-最新全套文件
  20. 爬取了同事的微博粉丝,结果发现300+涨粉中,真爱粉只有4个!

热门文章

  1. QT中16进制二进制字符串的转换
  2. Flutter中打包Android项目及升级Android项目
  3. html clear属性值,CSS clear both清除浮动
  4. 更简洁的 CSS 清理浮动方式(使用 :after 伪类来提供浮动块后的 clear:both)
  5. 万网云虚拟主机 mysql_万网虚机_虚拟主机购买_云虚拟主机租用_网站空间价格_虚拟云主机 - 阿里云...
  6. 征服Node.js 7.x视频课程(1):Node.js入门-李宁-专题视频课程
  7. 跟李宁老师学Python视频课程(11):正则表达式-李宁-专题视频课程
  8. 申请、使用 twilio那些事
  9. 面试题:如何设计一个权限系统?
  10. SpringBoot系列之canal和kafka实现异步实时更新