输出一点的对称点,两点间的距离

原创 2012年03月28日 16:14:13

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:                              * 作    者:   苗影                           * 完成日期:     2012    年   3    月     28   日 * 版 本 号:         

* 对任务及求解方法的描述部分 * 输入描述: * 问题描述: * 程序输出: * 程序头部的注释结束 */

#include<iostream>
#include<Cmath>
using namespace std;
enum SymmetricStyle { axisx,axisy,point};//分别表示按x轴, y轴, 原点对称
class CPoint
{
private:
	mutable double x;  // 横坐标
	mutable double y;  // 纵坐标
public:
	CPoint(double xx=0,double yy=0);
	double Distance(CPoint p) const;   // 两点之间的距离(一点是当前点,另一点为参数p)
	double Distance0() const;          // 到原点的距离
	CPoint SymmetricAxis(SymmetricStyle style) const;   // 返回对称点
	void input();  //以x,y 形式输入坐标点
	void output(); //以(x,y) 形式输出坐标点
};
CPoint::CPoint(double xx,double yy)
{
	x=xx;
	y=yy;
}
//以x,y 形式输入坐标点
void CPoint::input()
{
	char c;
	double xx,yy;
	while(1)
	{
		cout<<"请按照x,y格式输入"<<endl;
		cin>>xx>>c>>yy;
		if(c!=',')
			cout<<"格式不对,请重新输入"<<endl;
		else
			break;
	}
	x=xx;
	y=yy;
}
// 到原点的距离
double CPoint::Distance0()const 
{
	double s;
	s=sqrt(x*x+y*y);
	return s;
}
// 两点之间的距离(一点是当前点,另一点为参数p)
double CPoint::Distance(CPoint p) const
{
	double s;
	s=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));//注意p坐标的表达方式
	return s;
} 
// 返回对称点
CPoint CPoint::SymmetricAxis(SymmetricStyle style) const
{
	switch(style)
	{
	case axisx:
		y=-y;
		cout<<'('<<x<<','<<y<<')'<<endl;break;
	case axisy:
		x=-x;
		cout<<'('<<x<<','<<y<<')'<<endl;break;
	case point:
		x=-x;
		y=-y;
		cout<<'('<<x<<','<<y<<')'<<endl;break;
	}
	return 0;
}
//以(x,y) 形式输出坐标点
void CPoint::output()
{
	cout<<'('<<x<<','<<y<<')';
}
int main()
{
	CPoint c1(2,3),c2(2,1),c3;
	cout<<"这两点";
	c1. output();
	c2.output();
	cout<<"之间的距离为:"<<c1. Distance(c2);
	cout<<endl;
	c1. output();
	cout<<"到原点的距离为:"<<c1.Distance0();
	cout<<endl;
	c2. output();
	cout<<"到原点的距离为:"<<c2.Distance0();
	cout<<endl;
	c3.input();
	cout<<"这两点";
	c1. output();
	c3.output();
	cout<<"之间的距离为:"<<c3. Distance( c1);
	cout<<endl;
	c3. output();
	cout<<"到原点的距离为:"<<c3.Distance0();
	cout<<endl;
	c3.output();
	cout<<"关于x轴的对称点:";
	c3.SymmetricAxis(axisx);
	cout<<endl;
	c1.output();
	cout<<"关于y轴的对称点:";
	c1.SymmetricAxis(axisy);
	cout<<endl;
	c2.output();
	cout<<"关于原点的对称点:";
	c2.SymmetricAxis(point);
	cout<<endl;
	return 0;
}
 
经验积累:我以前很不习惯用switch语句,不过习惯了它还是比较方便的.

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

C++第六周任务三设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:设计...

【任务3】设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等

* 程序头部注释开始* 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved.* 文件名称: * 作 者: ...

第六周任务三设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved.* 文件名称: *...

hdu 2857(对称点与直线交点问题)

Mirror and Light Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Oth...

WV.12-枚举-平面点的对称点

问题及代码: /* *Copyright (c)2014,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:xy.cpp *作 者:单昕昕 ...

HDU 2671 Can't be easier 求点关于直线的对称点

/* 显然,如果A,B在直线的同一侧,则min(PA+PB)=dis(A,B), 否则,求出B关于直线的对称点B`,min(PA+PB)=dis(A,B`) */ #include #include ...

【枚举】项目一。求对称点

上机内容:C++程序的编写和运行 上机目的:掌握简单C++程序的编辑、编译、连接和运行的一般过程 我的程序:/* Copyright (c) 2013, 烟台大学计算机学院 * All right...

tzc3056 点关于直线的对称点

题目链接:  tzc3056 方法:计算几何  注意:本题在输出结果的时候要将数据强制转换成整型,不能用%.0lf输出,否则会WA。 代码: #include #include usi...

学术休假期 项目3(2)-平面点的对称点

问题及代码: 设计函数,可以按指定的方式,输出一个平面点的对称点 下面给出枚举类型定义和main函数(测试函数),请写出output函数的实现。 /* *Copyright (c)2014,烟台...

C++找对象的季节——常成员函数(点和对称点)

又到了一周一次的发博文时间了,废话不多说,马上开始: #include #include using namespace std; class CPoint { private: doubl...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)