题目描述
输入球的中心点和球上某一点的坐标,计算球的半径和体积
输入描述:
球的中心点和球上某一点的坐标,以如下形式输入:x0 y0 z0 x1 y1 z1
输出描述:
输入可能有多组,对于每组输入,输出球的半径和体积,并且结果保留三位小数 为避免精度问题,PI值请使用arccos(-1)。
示例1
输入
0 0 0 1 1 1
输出
1.732 21.766
S圆:
V球:
V圆锥:
S球(表面积):S=4πr²=πD²
#include <iostream>
#include <vector>
#include <algorithm>
#include <cmath>
#include <cstdio>
using namespace std;
// pi == arccos(-1)
double getR(double x1, double y1, double z1, double x2, double y2, double z2) {
double x = x2 - x1;
x *= x;
double y = y2 - y1;
y *= y;
double z = z2 - z1;
z *= z;
double res = sqrt (x + y + z);
return res;
}
double getV(double r) {
double r3 = r * r * r;
double pi = acos(-1);
return 4 / 3.0 * pi * r3;
}
int main() {
double x1;
double y1;
double z1;
double x2;
double y2;
double z2;
while (cin >> x1 >> y1 >> z1 >> x2 >> y2 >> z2) {
double r = getR(x1,y1,z1,x2,y2,z2);
double v = getV(r);
printf("%.3f %.3f\n",r,v);
}
}