2017final函数模板
数据的间距问题(函数模板) 类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时标志输入结束。
代码实现
#include<iostream>
#include<cmath>
using namespace std;
class Point
{
public:
Point(double a, double b, double c) :x(a), y(b), z(c) {}
friend double operator -(Point p1, Point p2);
private:
double x;
double y;
double z;
};
double operator -(Point p1, Point p2)
{
return sqrt(pow(p1.x - p2.x, 2.0) + pow(p1.y - p2.y, 2.0) + pow(p1.z - p2.z, 2.0));
}
template<class T1, class T2>
double Distance(T1 a, T2 b)
{
return abs(a - b);
}
int main()
{
int n;
cin >> n;
while (n != 0)
{
if (n == 1)
{
int a, b;
cin >> a >> b;
cout << Distance(a, b) << endl;
}
if (n == 2)
{
float a, b;
cin >> a >> b;
cout << Distance(a, b) << endl;
}
if (n == 3)
{
double a1, b1, c1, a2, b2, c2;
cin >> a1 >> b1 >> c1 >> a2 >> b2 >> c2;
Point p1(a1, b1, c1);
Point p2(a2, b2, c2);
cout << Distance(p1, p2) << endl;
}
cin >> n;
}
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通