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

原创 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语句,不过习惯了它还是比较方便的.

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

#include #include #include using namespace std; class CPoint { private: double x; // 横坐标 double y...
  • u012519969
  • u012519969
  • 2014年01月14日 17:33
  • 736

地球上两点间最短距离及计算方法

地球上两点间最短距离及走法 一、为什么说“地球表面两地之间的最短距离是通过这两点的大圆的劣弧段”?                                  如上左图...
  • csluqiang
  • csluqiang
  • 2014年01月18日 14:11
  • 4951

图论03—任意两点间最短距离及路径(改进)

======================================================== 重要程度 ***** 求任意两点间最短距离及其路径。(万能最短路) 输入:权值矩阵,起...
  • LZX19901012
  • LZX19901012
  • 2015年08月21日 12:08
  • 999

hdu 2376(求树上任意两点之间距离之和的平均值)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2376 思路: 引:如果暴力枚举两点再求距离是显然会超时的。转换一下思路,我们可以对每条边,求所有可...
  • zjsyhjh
  • zjsyhjh
  • 2014年05月26日 18:00
  • 941

图中指定两点间的最短距离

知识点: 1、针对vector类型的遍历 Vector vec; For(char ch: vec) {//ch就是vec中存储的值}   ???vec为空 2、对于递归函数,可以巧用静态变量。递归函...
  • bxw1992
  • bxw1992
  • 2017年07月05日 21:51
  • 145

OPENCV 两点之间的操作

#include #include #include #include "cxcore.h" #include #include using namespace std; ...
  • u012767067
  • u012767067
  • 2014年02月18日 11:22
  • 6621

GPS两点的距离

目前手头的一个项目要用到GPS地理定位信息,很自然的就需要知道两个地点之间的距离,于是上网找了一下,同样自然的就有一些算法贴出来。。(网络真是帮了大忙,省得我再去翻几何书自己研究算法了!公式早都忘光了...
  • chary8088
  • chary8088
  • 2013年12月18日 21:21
  • 4389

POJ1125 求有向图中两点的最短路径问题

POJ 1125 典型的求解有向图中两个的最短路径问题: 如果求图中任意两点的最短路径,则使用flyod算法。 如果求图中给定两点的距离,则用dijkstra算法. Floyd算法: int ma...
  • kuangminan
  • kuangminan
  • 2015年06月17日 21:22
  • 1546

用一般函数设计点类求两点之间的距离

/* *Copyright (c) 2016,烟台大学计算机学院 *All rights reserved. *文件名称:zyq.cpp *作 者:赵彦庆 *完成日...
  • duchunshui
  • duchunshui
  • 2016年04月13日 22:31
  • 555

关于已知两点经纬度求球面最短距离的公式推导

已知两点经纬度计算球面距离的公式,一搜一大堆,形式如下: 可是至于这个公式为什么是这样的,今天推导了一下,详细推导过程如下。首先画个图(图1),要不然空间想象能力差的话容易犯糊涂。首先对图1...
  • yu412346928
  • yu412346928
  • 2015年01月21日 11:34
  • 935
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:输出一点的对称点,两点间的距离
举报原因:
原因补充:

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