第6周-任务3-设计平面坐标点类

简介: 【题目】设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等enum SymmetricStyle { axisx,axisy,point};//分别表示按x轴, y轴, 原点对称class CPoint{private: double x; // 横坐标 double y; // 纵坐标public: CPoint(double x

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

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) const;   // 两点之间的距离(一点是当前点,另一点为参数p)
    double Distance0() const;         // 到原点的距离
    CPoint SymmetricAxis(SymmetricStyle style) const;   // 返回对称点
    void input();  //以x,y 形式输入坐标点
    void output(); //以(x,y) 形式输出坐标点
};


【分析】本题中引入的新内容包括:(1)对象作函数的参数:double Distance(CPoint p) const,同时,这个函数是常成员函数;(2)函数的返回值类型不是简单类型,而是类:CPoint SymmetricAxis(SymmetricStyle style) const,使用枚举类型可能对一些同学而言也并熟悉。


【讲解视频】



【参考解答】

#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) const;   // 两点之间的距离
	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;
}

// 输入坐标点
void CPoint::input()
{
	char ch;
	cout<<"请输入坐标点(格式x,y ):";
	while(1)
	{
		cin>>x>>ch>>y;
		if (ch==',') break;
		cout<<"输入的数据格式不符合规范,请重新输入\n";
	}
}

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

// 求两点之间的距离
double CPoint::Distance(CPoint p) const
{
	double d;
	d=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));//将(p.x-x)更改为(p.x-this->x)可以更便于理解,d是当前点*this和参数给出的点p间的距离
	return d;
}

// 求点到原点的距离
double CPoint::Distance0() const
{
	double d;
	d=sqrt(x*x+y*y);
	return d;
}

// 求对称点
CPoint CPoint::SymmetricAxis(SymmetricStyle style) const
{
	CPoint p(this->x,this->y);//用复制构造函数时,写作p(*this)
	switch(style)
	{
	case axisx:
		p.y=-y; break;
	case axisy:
		p.x=-x; break;
	case point:
		p.x=-x;p.y=-y;
	}
	return p;
}

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

对比第46行开始的CPoint::Distance(CPoint p)函数定义理解下面的内容。

 

【要点理解】

有同学提出能不能在参数中给出两点,求这两点间的距离?当然可以。看下面的例子

#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 getX(){return x;}
	double getY(){return y;}
};

double distance(CPoint p1,CPoint p2)
{
	double d;
	d=sqrt((p1.getX()-p2.getX())*(p1.getX()-p2.getX())+(p1.getY()-p2.getY())*(p1.getY()-p2.getY()));
	return d;
}


void main( )
{
	double d;
	CPoint p1(2,3),p2(-5,1);
	d=distance(p1,p2);
	cout<<"两点的距离为:"<<d<<endl;
	system("pause");
}


【讨论】这里涉及到两种对求距离的处理方法

方法1:用类的成员函数实现

成员函数的定义

// 求两点之间的距离
double CPoint::Distance(CPoint p) const
{
	double d;
	d=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));//将(p.x-x)更改为(p.x-this->x)可以更便于理解,d是当前点*this和参数给出的点p间的距离
	return d;
}
调用成员函数求距离:

	double d;
	CPoint p1(2,3),p2(-5,1);
	d=p1.distance(p2); //或d=p2.distance(p1);
方法2:用一般函数实现

double distance(CPoint p1,CPoint p2)//注意:这不是类的成员函数
{
	double d;
	d=sqrt((p1.getX()-p2.getX())*(p1.getX()-p2.getX())+(p1.getY()-p2.getY())*(p1.getY()-p2.getY()));
	return d;
}
调用函数求距离:

	double d;
	CPoint p1(2,3),p2(-5,1);
	d=distance(p1,p2);
(1)在方法1中函数调用d=p1.distance(p2);是典型的面向对象思维,求距离distance是对象p1的行为,是p1的功能,是p1求对p2的距离,p1是这个动作的发起者,p2为这个动作提供数据;方法2是面向过程的思维,在main()函数中,由main()作主求距离,求的是p1和p2距离,p1和p2地位平等。

(2)在方法1中,p1的数据成员x和y在类的成员函数中可以直接使用,也可以用this->x和this->y访问,这是内部事务;而在方法2中,已经不是类的地盘所在,p1.x、p1.y不能访问对象中的私有成员,需要定义访问私有成员的接口getX()和getY(),才能得到对象中x和y的值,信息隐藏在此发威。



(本文完)

目录
相关文章
|
数据可视化 测试技术 开发工具
吭哧吭哧开发2周,老板突然说这个功能不要了。。。
吭哧吭哧开发2周,老板突然说这个功能不要了。。。
吭哧吭哧开发2周,老板突然说这个功能不要了。。。
|
Android开发 Java 小程序
第11周学习进度
时间   学习花费的时间 代码量 博客量 了解到的知识点 第11周 周一晚上(9:00-10:00)看了一些jsp的视频 周二(8:00-9:50)软件工程概论 周二,周三,周四下午都拿出了两个小时来学android 1500 3 代码的规范,小程序的基本操作
707 0
|
消息中间件
工作周记 - 第七周 (2016/07/04 - 2016/07/08)
1、拆分消息队列   原本在登录注册的时候需要使用到短信发送,这个需要使用到消息队列,当时只放入在项目中   现在的新需求在各个环节都有不同的消息推送,短息服务,以及日志保存,这些索性单独拎出来作为一个服务提供   (消息队列采用RabbitMQ,各位看管有兴趣可以参考之前发的文章,另外MQ也...
816 0
|
数据库
工作周记 - 第五周 (2016/06/20 - 2016/06/25)
研发工作已经步入正轨 1、订单流程的设计,本周全体过了一遍订单流程,针对一些细节具体讨论,另外对于复杂的顶级权限账号详细细分,权限细分化   设计数据库模型,生成数据库表 2、coding,代码还是需要编写的,没什么好说的,就是正对业务的一些增删改查,具体的技术点会在非日志类写明 3、rev...
708 0
|
自然语言处理 IDE 开发工具
2015级C++第16周实践项目 文件
本周项目中用到的数据文件,请在此下载点这儿…。 【项目1 - 小玩文件】参考解答 (1)下面程序的功能是统计文本文件abc.txt中的字符个数,请填空将程序补充完整。 #include &lt;iostream&gt; #include &lt;cstdlib&gt; #include _____________ // (1) using namespace std;
1287 0
|
测试技术 C++
2015级C++第5周项目 类和对象
【项目1 - 三角形类雏形】 [参考解答] (1)下面设计一个三角形类,请给出各成员函数的定义 class Triangle { public: void setABC(double x, double y, double z);//置三边的值,注意要能成三角形 double perimeter();//计算三角形的周长 double area
1191 0
|
C++
2015级C++第4周项目 函数
【项目1-求最大公约数】 参考解答 (1)输入两个数,并求出其最大公约数 #include &lt;iostream&gt; using namespace std; //自定义函数的原型(即函数声明) int main() { int a,b,g; cin&gt;&gt;a&gt;&gt;b; g=gcd(a,b); cout&lt;
1143 0
|
C++
2015级C++第3周实践项目
【项目1:个人所得税计算器】 编写选择结构程序,输入个人月收入总额,计算出他本月应缴税款和税后收入(计算办法见附:关于个人所得税的有关背景知识)。 (1)自选if语句的嵌套或/和switch语句完成程序设计; (2)下面给出程序的基本框架,请从课程主页找到链接下载使用。 #include &lt;iostream&gt; using namespace st
1343 0
|
C++
2015级C++第2周实践项目
【项目1 - 宣告“主权”】   你已经是CSDN博客主了,用IT人特有的方式,编一段程序,在屏幕上输出你想说的话,按要求发布博文,作为我们的开山之作。 【项目2 - 胖子不想说体重】参考解答   成年男性的标准体重公式为: 标准体重(kg)=身高(cm)−100  标准体重(kg)= 身高(cm)-100   超标准体重20%为超重,比标准体重轻20%为超轻。请编写
1071 0
|
C#
编程乐趣:C#获取日期所在周、月份第一和最后一天
原文: 编程乐趣:C#获取日期所在周、月份第一和最后一天 写了个小功能,需要用到以周为时间段,于是写了个获取周第一和最后一天的方法,获取月份的第一和最后一天就比较简单了。
844 0