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

原创 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. * 文件名称: 点...

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

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

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

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

第六周任务三之平面坐标点

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

第六周任务3:平面坐标点类

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

第六周任务3(设计平面坐标点类)

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

任务三:设计平面坐标点类

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

第六周实验报告 任务三

#include #include using namespace std; enum SymmetricStyle { axisx,axisy,point};//分别表示按x轴, y轴, 原点对称 ...

C++程序设计实验报告(四十五)---第六周任务三

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

第六周实验报告(三)

* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:类关于...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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