数据的间距问题(函数模板) 类point有三个数据成员:x、y和z, 分别代表x坐标、y坐标和z坐标,并有若干构造函数和一个重载-(减号,计算两点距离)的成员函数。 要求设计一个函数模板,
template < class T> double dist(T a, T b)
对int,float,point或者其他类型的数据,返回间距。
输入格式:
每一行为一个操作,每行的第一个数字为元素类型,1为整型元素,2为浮点型元素,3为point类型,若为整型元素,接着输入两个整型数据,若为浮点型元素,接着输入两个浮点型数据,若为point型元素,输入两个point型数据(x1 y1 z1 x2 y2 z2),输入0时标志输入结束。
输出格式:
对每个输入,每行输出一个间距值。
输入样例:
1 2 5
3 2 4 7 5 9 7
2 2.2 9.9
0
输出样例:
3
5.83095
7.7
AC代码
#include<cmath>
#include<cstdio>
#include<algorithm>
#include<string>
#include<vector>
#include<iomanip>
#include<iostream>
using namespace std;
typedef long long ll;
class point{
public :
point(double a1,double b1,double c1){
a=a1;
b=b1;
c=c1;
}
friend double operator - (point a, point b);
private:
double a,b,c;
};
double operator - (point a, point b){
return sqrt(pow(a.a - b.a, 2.0) + pow(a.b - b.b, 2.0)+ pow(a.c - b.c, 2.0));
}
template <class T>
double dist(T a, T b){
return abs(a-b);
}
int main() {
int n;
cin>>n;
while(n){
if(n==1){
int a,b;
cin>>a>>b;
cout<<dist(a,b)<<endl;
}
else if(n==2){
float a,b;
cin>>a>>b;
cout<<dist(a,b)<<endl;
}
else if(n==3){
double a1,b1,c1,a2,b2,c2;
cin>>a1>>b1>>c1>>a2>>b2>>c2;
point a(a1,b1,c1),b(a2,b2,c2);
cout<<dist(a,b)<<endl;
}
cin>>n;
}
return 0;
}