PTA:7-85 数据的间距问题(重载+函数模板)

三个类如下设计:类cTime有三个数据成员,hh,mm,ss,分别代表时,分和秒,并有若干构造函数和一个重载-(减号)的成员函数。类point有两个数据成员,x,y分别坐标,并有若干构造函数和一个重载-(减号)的成员函数。类date有三个数据成员,year,month,day分别代表年月日,并有若干构造函数和一个重载-(减号)的成员函数。 要求设计一个函数模板template <\class T>\ double dist(T a, T b) 对int,float,cTime,point和date或者其他类型的数据,返回间距。

其中,hh = 3600 ss, mm = 60 ss, year = 365 day, month = 30 day,对于cTime和date类型,数据在转换成ss或者day后进行运算。

输入格式:

每一行为一个操作,每行的第一个数字为元素类型,1为整型元素,2为浮点型元素,3为point类型,4,为time类型,5为date类型,若为整型元素,接着输入两个整型数据,

若为浮点型元素,接着输入两个浮点型数据,若为point型元素,输入两个point型数据(x1 y1 x2 y2),若为time型元素, 输入两个cTime型数据(hh1 mm1 ss1 hh2 mm2 ss2),若为date型数据,输入两个date型数据(year1 month1 day1 year2 month2 day2)。输入0时标志输入结束。

输出格式:

对每个输入,每行输出一个间距值。

样例输入:

1 2 5

4 18 21 22 18 20 31

3 2 4 5 9

5 2013 5 14 2013 5 15

2 2.2 9.9

0

样例输出:

3

51

5.83095

1

7.7

#include<iostream>
#include<cmath>
using namespace std;
class Time
{
	int hh;
	int mm;
	int ss;
	public:
		Time(){;}
		void set(int h,int m,int s)
		{
			hh=h;
			mm=m;
			ss=s;
		}
		int operator-(const Time t)
		{
			long int s1=hh*3600+mm*60+ss;
			long int s2=t.hh*3600+t.mm*60+t.ss;
			if(s1>s2)
			return s1-s2;
			else
			return s2-s1;
		}
};
class point
{
	int x;
	int y;
	public:
		point(){;}
		void set(int a,int b)
		{
			x=a;
			y=b;
		}
		double operator -(point p)
		{
			return sqrt((x-p.x)*(x-p.x)+(y-p.y)*(y-p.y));
		}
};
class Date {
	private:
		int year,month,day;
	public:
		Date(){;}
		void set(int y,int m,int d) 
		{
			year = y;
			month = m;
			day = d;
		}
		int operator -(Date sec)
		{
			int totalDay1=year*365+month*30+day;
     		int totalDay2=sec.year*365+sec.month*30+sec.day;
    		return totalDay1-totalDay2;
		}
};
template<class T>
double dist(T a,T b)
{
	return fabs(a-b);
}
int main()
{
	int type;
	cin>>type;
	int a,b;
	float f1,f2;
	int x1,x2,y1,y2;
	int yy1,yy2,mm1,mm2,dd1,dd2;
	int h1,h2,m1,m2,s1,s2;
	Date sample1,sample2;
	point p1,p2;
	Time t1,t2;
	while(type!=0)
	{
		switch(type)
		{
			case 1:
				cin>>a>>b;
				cout<<dist(a,b)<<endl;
				break;
			case 2:
				cin>>f1>>f2;
				cout<<dist(f1,f2)<<endl;
				break;
			case 3:
				cin>>x1>>y1>>x2>>y2;
				p1.set(x1,y1);
				p2.set(x2,y2);
				cout<<dist(p1,p2)<<endl;
				break;
			case 4:
				cin>>h1>>m1>>s1>>h2>>m2>>s2;
				t1.set(h1,m1,s1);
				t2.set(h2,m2,s2);
				cout<<dist(t1,t2)<<endl;
				break;
			case 5:
				cin>>yy1>>mm1>>dd1>>yy2>>mm2>>dd2;
				sample1.set(yy1,mm1,dd1);
				sample2.set(yy2,mm2,dd2);
				cout<<dist(sample1,sample2)<<endl;
				break;
		}
		cin>>type;
	}
}
全部评论

相关推荐

小红书 后端选手 n*16*1.18+签字费期权
点赞 评论 收藏
分享
双非坐过牢:非佬,可以啊10.28笔试,11.06评估11.11,11.12两面,11.19oc➕offer
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务