第六周 任务三

原创 2012年03月25日 20:52:26
/*实验目的:设计平面坐标点类 
实验内容:设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等
* 程序的版权和版本声明部分  
* Copyright (c) 2011, 烟台大学计算机学院学生  
* All rights reserved.  
* 文件名称: 设计平面坐标点类                             
* 作    者:  薛广晨                             
* 完成日期:  2012       年  3    月  25      日  
* 版 本号:  x1.0         
  
* 对任务及求解方法的描述部分  
* 输入描述:计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等

* 程序头部的注释结束(此处也删除了斜杠)  
*/
//【任务3】设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等
#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){};
    void Distance(CPoint p) const; // 两点之间的距离(一点是当前点,另一点为参数p)
    void Distance0() const;       // 到原点的距离
    CPoint SymmetricAxis(SymmetricStyle style) const; // 返回对称点
    void input(); //以x,y 形式输入坐标点
    void output(); //以(x,y) 形式输出坐标点
};

void CPoint :: Distance(CPoint p) const      // 两点之间的距离(一点是当前点,另一点为参数p)
{
	
	double d;
	d = sqrt((p.x - x) * (p.x - x) + (p.y - y) * (p.y - y));
	cout << "两点之间的距离:" << d << endl;
}

void CPoint :: Distance0() const      // 到原点的距离
{
	double d;
	d = sqrt((x - 0) * (x - 0) + (y - 0) * (y - 0));
	cout << "到原点的距离:" << d << endl;
}

CPoint CPoint::SymmetricAxis(SymmetricStyle style) const   // 返回对称点
{
	switch(style)
	{
	case axisx: cout << "(" << x << "," << y << ")" <<"与" << "(" << x << "," << -y << ")" << "关于x轴对称" << endl ; break;
	case axisy: cout << "(" << x << "," << y << ")" <<"与" << "(" << -x << "," << y << ")" << "关于y轴对称" << endl; break;
	case point: cout << "(" << x << "," << y << ")" <<"与" << "(" << -x << "," << -y << ")" << "关于原点对称" << endl; break;
	}
	return(x,y);
}

void CPoint :: input() //以x,y 形式输入坐标点
{
	char c1, c2, c3;
	cout << "请输入坐标(形式 (x,y))";
	do
	{
		cin >> c1 >> x >> c2 >> y >> c3;
		if(c1 != '(' || c2 != ',' || c3 != ')')cout << "格式错误,请重新输入(形式 x,y)";
		else break;
	}while(1);
}

void CPoint :: output() //以(x,y) 形式输出坐标点
{
	cout << "(" << x << "," << y << ")" << endl;
}


int main()
{
	CPoint c1, c2;
	c1.input();

	cout << "请再输入一个点" << endl;
	c2.input();
	c1.Distance(c2);

	c1.Distance0();

	c1.SymmetricAxis(axisx);

	c1.SymmetricAxis(axisy);

	c1.SymmetricAxis(point);

	return 0;
}
    



上机感言:const类型也太霸道了吧,无法改变值啊

相关文章推荐

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

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

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

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

第六周任务三 坐标点

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

第六周实验报告 任务三(改进)

源代码: #include #include using namespace std; enum SymmetricStyle { axisx,axisy,point};//分别表...

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

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

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

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

点类的应用(第六周任务《三》)

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

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

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

第六周任务三(坐标点类)

问题描述:设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等 #include #include using namespace std; enum Symmetri...

第六周实验报告 任务4 设计一个三角形类 输入三角形的三个顶点 求面积周长

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生  * All rights reserved. * 文件名称:设计...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:第六周 任务三
举报原因:
原因补充:

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