题目要求
数据的间距问题(函数模板) 类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
解题思路
-
定义一个类 Point 表示三维坐标点,并实现两个 Point 对象之间的距离计算。
-
实现一个函数模板 dist,用于计算任意类型的数据之间的距离。该函数模板的输入参数可以是 int、float、Point 或者其他类型的数据,返回值为两个数据之间的间距。
-
在主函数中,通过不断读入输入的元素类型和数据内容,根据输入调用不同类型的 dist 函数进行计算,并输出计算结果。
需要注意的是,整型和浮点型数据之间的距离可以直接通过取差值计算,而 Point 类型的数据之间的距离需要调用 operator- 进行计算。因此,在主函数中需要对不同类型的数据进行不同的处理。
代码
#include<iostream>
#include<cmath>
using namespace std;
// 定义 Point 类表示三维坐标点
class Point{
private:
double x;
double y;
double z;
public:
// Point 类构造函数,用于初始化 x、y、z 三个数据成员
Point(double a,double b,double c):x(a),y(b),z(c){
};
// 友元函数,实现两个 Point 对象之间的距离计算
friend double operator-(Point,Point);
};
// 函数模板,用于计算任意类型的数据之间的距离
template <class T>
double dist(T a, T b){
return abs(a-b);
}
// 重载 - 运算符,计算两个 Point 对象之间的距离
double operator-(Point P1,Point P2){
return sqrt(pow(P1.x-P2.x,2)+pow(P1.y-P2.y,2)+pow(P1.z-P2.z,2));
}
// 主函数入口
int main(){
int i, j;
float p, q;
double x1, y1, z1, x2, y2, z2;
int flag;
while(1){
cin >> flag;
if(flag == 0){
break;
}
if(flag == 1){
cin >> i >> j;
// 调用 dist 模板函数计算 i 和 j 之间的间距,并输出
cout << dist(i, j) << endl;
} else if(flag == 2){
cin >> p >> q;
// 调用 dist 模板函数计算 p 和 q 之间的间距,并输出
cout << dist(p, q) << endl;
} else{
cin >> x1 >> y1 >> z1 >> x2 >> y2 >> z2;
Point P1(x1, y1, z1), P2(x2, y2, z2);
// 调用 operator- 函数计算 P1 和 P2 之间的距离,并输出
cout << dist(P1, P2) << endl;
}
}
return 0;
}
总结
该题考察函数模板相关知识点,读者可躬身实践。
我是秋说,我们下次见。