简单的几何题,先把经纬度换算成球面坐标,再把球面坐标换算成直角坐标,然后求夹角,乘半径得到球面距离
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
/**//*************************************************************************
Author: WHU_GCC
Created Time: 2007-10-2 10:18:27
File Name: pku3407.cpp
Description:
************************************************************************/
#include <iostream>
#include <cmath>
using namespace std;
#define out(x) (cout<<#x<<": "<<x<<endl)
const int maxint=0x7FFFFFFF;
typedef long long int64;
const int64 maxint64 = 0x7FFFFFFFFFFFFFFFLL;
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
template<class T>void show(T a, int n)
{for(int i=0; i<n; ++i) cout<<a[i]<<' '; cout<<endl;}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
template<class T>void show(T a, int r, int l)
{for(int i=0; i<r; ++i)show(a[i],l);cout<<endl;}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
const double pi = acos(-1.0);
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
int main()
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
double theta, phi, theta_m, phi_m;
double theta1, phi1, theta2, phi2;
char s1[10], s2[10];
while (scanf("%lf%lf%s%lf%lf%s", &theta, &theta_m, s1, &phi, &phi_m, s2) != EOF)
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
theta += theta_m / 60;
phi += phi_m / 60;
if (strcmp(s1, "N") == 0)
theta1 = 90 - theta;
else
theta1 = 90 + theta;
if (strcmp(s2, "E") == 0)
phi1 = phi;
else
phi1 = 360 - phi;
scanf("%lf%lf%s%lf%lf%s", &theta, &theta_m, s1, &phi, &phi_m, s2);
theta += theta_m / 60;
phi += phi_m / 60;
if (strcmp(s1, "N") == 0)
theta2 = 90 - theta;
else
theta2 = 90 + theta;
if (strcmp(s2, "E") == 0)
phi2 = phi;
else
phi2 = 360 - phi;
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
theta1 = theta1 * pi / 180;
theta2 = theta2 * pi / 180;
phi1 = phi1 * pi / 180;
phi2 = phi2 * pi / 180;
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
double p = 6370.0;
double x1, y1, z1, x2, y2, z2;
x1 = p * sin(theta1) * cos(phi1);
y1 = p * sin(theta1) * sin(phi1);
z1 = p * cos(theta1);
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
x2 = p * sin(theta2) * cos(phi2);
y2 = p * sin(theta2) * sin(phi2);
z2 = p * cos(theta2);
double alpha = acos((x1 * x2 + y1 * y2 + z1 * z2) / ((sqrt(x1 * x1 + y1 * y1 + z1 * z1)) * (sqrt(x2 * x2 + y2 * y2 + z2 * z2))));
printf("%.3lf\n", alpha * p);
}
return 0;
}