关闭

第6周实验报告3

282人阅读 评论(0) 收藏 举报
#include <iostream>

#include <cmath>

using namespace std;

enum SymmetricStyle {axisx,axisy,point};//分别表示按x轴, y轴, 原点对称

class CPoint
{
private:

	double x;  // 横坐标

	double y;  // 纵坐标

public:

	CPoint(double xx=0,double yy=0):x(xx), y(yy){}

	double Distance(CPoint p) const;   // 两点之间的距离(一点是当前点,另一点为参数p)

	double Distance0() const;          // 到原点的距离

	CPoint SymmetricAxis(SymmetricStyle style) const;   // 返回对称点

	void input();  //以x,y 形式输入坐标点

	void output(); //以(x,y) 形式输出坐标点
};

int main ()
{
	CPoint c, p;

	c.input();

	p.input();

	double mm;

	mm = c.Distance(p);

	cout << "两点之间的距离为:" << mm << endl;

	mm = c.Distance0();

	c.output();

	cout << "到原点的距离为" << mm << endl;

	cout << "关于x, y, 原点的对称点分别是:" << endl;
	
	c.SymmetricAxis(axisx);

	c.SymmetricAxis(axisy);

	c.SymmetricAxis(point);

	system ("pause");

	return 0;
}

void CPoint::input()
{
	cout << "请输入横坐标和纵坐标(x,y):" << endl;

	double a = 0, b = 0;

	char q;

	while (250)
	{
		cin >> a >> q >> b;

		if (a != 0 && b != 0 && q == ',')
		{
			break;
		}
		cout << "error! try again." << endl;
	}

	x = a;

	y = b;
}

void CPoint::output()
{
	cout << '(' << x << ',' << y << ')';
}

double CPoint::Distance(CPoint p) const
{
	return sqrt((x - p.x) * (x - p.x) + (y - p.y) * (y - p.y));
}

double CPoint::Distance0() const
{
	return sqrt(x * x + y * y);
}

CPoint CPoint::SymmetricAxis(SymmetricStyle style) const
{
	switch (style)
	{
	case 0:cout << '(' << x << ',' << -y << ')';break;

	case 1:cout << '(' << -x << ',' << y << ')';break;

	case 2:cout << '(' << -x << ',' << -y << ')';break;

	default:cout << "error!" << endl;
	}
	return 0;
}


0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:27128次
    • 积分:705
    • 等级:
    • 排名:千里之外
    • 原创:42篇
    • 转载:1篇
    • 译文:0篇
    • 评论:19条
    最新评论