题目描述
下面是一个平面上的点的类定义,请在类外实现它的所有方法,并生成点测试它。
输入
测试数据的组数 t
第一组测试数据点p1的x坐标 第一组测试数据点p1的y坐标 第一组测试数据点p2的x坐标 第一组测试数据点p2的y坐标
…
输出
输出p1到p2的距离
在C++中,输出指定精度的参考代码如下:
#include
#include //必须包含这个头文件
using namespace std;
void main( )
{ double a =3.141596;
cout<<fixed<<setprecision(3)<<a<<endl; //输出小数点后3位
}
输入样例1
2
1 2 3 4
-1 0.5 -2 5
输出样例1
Distance of Point(1.00,2.00) to Point(3.00,4.00) is 2.83
Distance of Point(-1.00,0.50) to Point(-2.00,5.00) is 4.61
#include<iostream>
#include<iomanip>
#include<math.h>
using namespace std;
class p
{
double x,y;
public:
p():x(0),y(0){}
p(double x_value,double y_value):x(x_value),y(y_value){}
double getx();
double gety();
void setx(double x_value);
void sety(double y_value);
double distance(p point);
};
double p::getx()
{return x;}
double p::gety()
{return y;}
void p::setx(double x_value)
{
x=x_value;
}
void p::sety(double y_value)
{
y=y_value;
}
double p::distance(p pp)
{
return sqrt((x-pp.x)*(x-pp.x)+(y-pp.y)*(y-pp.y));
}
int main()
{
int t;
cin>>t;
while(t--)
{
double x1,y1,x2,y2;
cin>>x1>>y1>>x2>>y2;
p p1(x1,y1);
p p2(x2,y2);
cout<<"Distance of Point("<<fixed<<setprecision(2)<<p1.getx()<<','<<p1.gety()<<") to Point("<<p2.getx()<<','<<p2.gety()<<") is "<<p1.distance(p2)<<endl;
}
return 0;
}