| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 
 | #include <iostream>#include <cstdio>
 #include <cmath>
 #include <cstring>
 #include <algorithm>
 #include <vector>
 #define ms(a,b) memset(a,b,sizeof(a))
 using namespace std;
 typedef long long ll;
 const int mod = 1e9 + 7;
 const int maxn = 100000 + 5;
 const double eps = 1e-8;
 const double pi = acos(-1.0);
 
 struct Point {
 double x, y, z;
 Point(double a = 0, double b = 0, double c = 0): x(a), y(b), z(c){}
 Point operator -(const Point &b)const {
 return Point(x - b.x, y - b.y,z-b.z);
 }
 Point operator +(const Point &b)const {
 return Point(x + b.x, y + b.y,z+b.z);
 }
 
 Point operator *(const double &k)const {
 return Point(x * k, y * k,z*k);
 }
 Point operator /(const double &k)const {
 return Point(x / k, y / k,z/k);
 }
 double operator *(const Point &b)const {
 return x*b.x + y*b.y+z*b.z;
 }
 };
 
 double dist(Point p1, Point p2) {
 return sqrt((p1 - p2)*(p1 - p2));
 }
 struct sphere {
 double r;
 Point centre;
 } a[maxn], sp;
 
 double SphereInterVS(sphere a, sphere b) {
 double d = dist(a.centre, b.centre);
 double t = (d*d + a.r*a.r - b.r*b.r) / (2.0 * d);
 double h = sqrt((a.r*a.r) - (t*t)) * 2;
 double angle_a = 2 * acos((a.r*a.r + d*d - b.r*b.r) / (2.0 * a.r*d));
 double angle_b = 2 * acos((b.r*b.r + d*d - a.r*a.r) / (2.0 * b.r*d));
 double l1 = ((a.r*a.r - b.r*b.r) / d + d) / 2;
 double l2 = d - l1;
 double x1 = a.r - l1, x2 = b.r - l2;
 double v1 = pi*x1*x1*(a.r - x1 / 3);
 double v2 = pi*x2*x2*(b.r - x2 / 3);
 return v1 + v2;
 }
 
 int n;
 
 int main(){
 int T, kase = 0; scanf("%d", &T);
 while (T--){
 scanf("%d", &n);
 for (int i = 1; i <= n; i++) scanf("%lf%lf%lf%lf", &a[i].centre.x, &a[i].centre.y, &a[i].centre.z, &a[i].r);
 scanf("%lf%lf%lf%lf", &sp.centre.x, &sp.centre.y, &sp.centre.z, &sp.r);
 double ans = 0;
 for (int i = 1; i <= n; i++) {
 double d1 = dist(a[i].centre, sp.centre);
 if (d1 < a[i].r + sp.r) {
 if (d1 + a[i].r < sp.r) {
 ans += 4.0 * pi / 3.0 * a[i].r * a[i].r * a[i].r;
 } else {
 ans += SphereInterVS(a[i], sp);
 }
 }
 }
 printf("Case #%d: %.10lf\n", ++kase, ans);
 }
 return 0;
 }
 
 |