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

标签: 任务 distance output input system class
518人阅读 评论(0) 收藏 举报
分类:
/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生 
* All rights reserved.
* 文件名称:                              
* 作    者:   臧鹏               
* 完成日期:   2012   年  3 月   27   日
* 版 本 号:          

* 对任务及求解方法的描述部分
* 输入描述: 
* 问题描述:设计平面坐标点类,计算两点之间的距离,到原点的距离,关于坐标轴和原点的对称点等,其中使用了枚举 
* 程序输出: 
* 程序头部的注释结束
*/
#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);
	double Distance(CPoint p);//两点之间的距离(一点是当前点,另一点为参数p)
	double Distance0() const;  //到原点的距离
	CPoint SymmetricAxis(SymmetricStyle style) const;//返回到对称点
	void input();//以x,y形式输入坐标点
	void output(); //以(x,y)形式输入坐标点
};

using namespace std;

CPoint::CPoint(double xx ,double yy ):x(xx),y(yy){}


double CPoint::Distance(CPoint p)//两点之间的距离(一点是当前点,另一点为参数p)
{
	return sqrt((x-p.x)*(x-p.x)+(y-p.y)*(y-p.y));
}


double CPoint::Distance0() const  //到原点的距离
{
	double m = 0;
	m = sqrt(x*x+y*y);
	return m;
}
CPoint CPoint::SymmetricAxis(SymmetricStyle style) const//返回到对称点
{
	CPoint p(x,y);
	switch(style)
	{
	case axisx: p.y = -y;
		break;
	case axisy: p.x = -x;
		break;

	case point:p.x = -x;
		p.y = -y;
		break;
	}
	return p;
}

void CPoint::input()//以x,y形式输入坐标点
{
	char a;
	cout<<"以x,y形式输入坐标点"<<endl;
	cin>>x>>a>>y;
	while(1)
	{
		if(a != ',')
		{
			cout<<"格式不正确请重新输入"<<endl;
		}
		else break;
	}
}
void CPoint::output() //以(x,y)形式输入坐标点
{
	cout<<'('<<x<<','<<y<<')'<<endl;
}

void main()
{
	double distance;
	CPoint p1,p2,p;
	cout<<"请输入第一个点p1"<<endl;
	p1.input();
	cout<<"请输入第二个点p2"<<endl;
	p2.input();
	distance = p1.Distance(p2);
	cout<<"两点距离为"<<distance<<endl<<endl;
	distance = p1.Distance0();
	cout<<"p1到原点的距离"<<distance<<endl;
	p = p1.SymmetricAxis(axisx) ; 
	cout<<"关于x轴对称点"<<endl;
	p.output();
	p = p1.SymmetricAxis(axisy) ;
	cout<<"关于y轴对称点"<<endl;
	p.output();
	p = p1.SymmetricAxis(point) ;
	cout<<"关于原点的对称点"<<endl;
	p.output();
	system("pause");
}

查看评论

Skinning Your Application

Skinning Your Application Larry RoofTonked.comDecember 11, 2001Knock, knock.Whos there?Angry develop...
  • sonicdater
  • sonicdater
  • 2002-02-18 12:08:00
  • 501

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

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

第六周——平面坐标点类

#include #include using namespace std; class CPoint { private: double x; // 横坐标 ...
  • u012313437
  • u012313437
  • 2014-04-01 12:55:08
  • 568

第5周项目--设计平面坐标点类+体验常成员函数

/* * Copyright (c) 2015, 烟台大学计算机学院 * All rights reserved. * 文件名称:test.cpp * 作 者:姜...
  • tingary
  • tingary
  • 2015-04-07 12:03:33
  • 274

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

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

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

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

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

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

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

/* * 程序的版权和版本声明部分 * Copyright (c)2013, 烟台大学计算机学院学生 * All rightsreserved. * 文件名称:...
  • lihui18363829082
  • lihui18363829082
  • 2013-04-09 09:16:04
  • 805

设计平面坐标点类

* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称: * ...
  • sdhzwuxia
  • sdhzwuxia
  • 2012-03-28 19:12:40
  • 622

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

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称: ...
  • sdtianqing594
  • sdtianqing594
  • 2012-03-27 20:46:01
  • 470
    个人资料
    持之以恒
    等级:
    访问量: 33万+
    积分: 4631
    排名: 7917
    最新评论