第六周实验报告(三)平面坐标类

原创 2012年03月26日 18:44:32

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生 
* All rights reserved.
* 文件名称: 设计平面坐标类,计算两点之间距离、到原点的距离、关于坐标轴和原点的对称点等                             
* 作    者:  晁阳                            
* 完成日期:  2012       年   03   月   26 日
* 版 本 号:t 1.1         

常对象(常变量)、指针、数组,这些熟悉的名字在面向对象中再次出现,本来就有一些对概念的朦胧感,这次又遇到就像在生活中碰到同学,只知道他是自己的童鞋,但是具体是那个专业哪个班的就不知道啦!只好回去翻翻前面的。现在新的算法接触的不多,主要新的概念,新的功能挺多的,如果不仔细分析不容易记忆,分辨,和利用。

#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) 形式输出坐标点
};

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 axisx:
		cout << "点(" << x << "," << y << ")" << "关于x轴的坐标为:(" << x << "," << -y << ")" << endl;
	case axisy:
		cout << "点(" << x << "," << y << ")" << "关于y轴的坐标为:(" << -x << "," << y << ")" << endl;
	case point:
		cout << "点(" << x << "," << y << ")" << "关于原点的坐标为:(" << -x << "," << -y << ")" << endl;
	}
	return 0;
}

void CPoint:: input()
{
	char ch = ',';
	cout << "请输入点的坐标:";
    cin >> x >> ch >> y;
	while (1)
	{
		if(ch != ',')
		{
			cout << "格式有误,请重新输入!";
			cin >> x >> ch >> y;
		}
		else
		{
			break;
		}
	}
}

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

void main()
{
	CPoint p1,p2;
	p1.input();
	p2.input();

	cout << "两点间的距离为:" << p1.Distance(p2) << endl;
	cout << "点p1距离原点的距离为:" << p1.Distance0() << endl;
    cout << "点p2距离原点的距离为:" << p2.Distance0() << endl;
    p1.SymmetricAxis(axisx);
	p2.SymmetricAxis(axisx);
	cout <<endl;
	system("pause");
	
}



第六周实验报告(任务三)【平面坐标点类】

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称: 点...
  • zhangpeipei2011
  • zhangpeipei2011
  • 2012年03月27日 20:22
  • 205

第六周项目三----平面坐标类

/* * 程序的版权和版本声明部分 * Copyright (c)2013, 烟台大学计算机学院学生 * All rightsreserved. * 文件名称: object.cpp * 作...
  • dongshidexiaohai
  • dongshidexiaohai
  • 2013年04月08日 12:27
  • 573

第六周——平面坐标点类

#include #include using namespace std; class CPoint { private: double x; // 横坐标 ...
  • u012313437
  • u012313437
  • 2014年04月01日 12:55
  • 566

第六周—3.平面坐标类

/* * 程序的版权和版本声明部分 * Copyright (c)2012, 烟台大学计算机学院学生 * All rightsreserved. * 文件名称: fun.cpp *...
  • JNWSGH
  • JNWSGH
  • 2013年04月06日 18:09
  • 771

第六周项目三:平面坐标点类

/* * 程序的版权和版本声明部分 * Copyright (c)2013, 烟台大学计算机学院学生 * All rightsreserved. * 文件名称: object.cpp * 作...
  • zylmtz2012
  • zylmtz2012
  • 2013年04月09日 08:49
  • 1143

第六周项目三—平面坐标点类

/* * 程序的版权和版本声明部分 * Copyright (c)2013, 烟台大学计算机学院学生 * All rightsreserved. * 文件名称: object.cpp * 作...
  • gintama2012
  • gintama2012
  • 2013年04月08日 10:50
  • 448

第六周 项目三:平面坐标点类

/* * 程序的版权和版本声明部分 * Copyright (c)2012, 烟台大学计算机学院学生 * All rightsreserved. * 文件名称: object.cpp * 作者: ...
  • liyang201258504411
  • liyang201258504411
  • 2013年04月07日 15:54
  • 763

第六周实验报告(三)

* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:类关于...
  • cailwen
  • cailwen
  • 2012年03月27日 20:44
  • 341

第六周实验报告 任务三

#include #include using namespace std; enum SymmetricStyle { axisx,axisy,point};//分别表示按x轴, y轴, 原点对称 ...
  • hb9206
  • hb9206
  • 2012年03月28日 18:46
  • 460

第六周项目3:平面坐标点类

/* * 程序的版权和版本声明部分 * Copyright (c)2013, 烟台大学计算机学院学生 * All rightsreserved. * 文件名称:...
  • lihui18363829082
  • lihui18363829082
  • 2013年04月09日 09:16
  • 799
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:第六周实验报告(三)平面坐标类
举报原因:
原因补充:

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