第六周 任务三

原创 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. * 文件名...
  • liuxiangyi887
  • liuxiangyi887
  • 2012年03月27日 21:01
  • 225

第六周实验报告 任务三

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

第六周任务三。

【题目】设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等 #include #include using namespace std; enum SymmetricS...
  • pinktinda
  • pinktinda
  • 2012年03月28日 19:40
  • 688

第六周作业任务三

(程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件...
  • zhangxindaisy
  • zhangxindaisy
  • 2012年03月28日 19:52
  • 188

第六周上机任务(三)

/* * 程序的版权和版本声明部分 * Copyright (c)2012, 烟台大学计算机学院学生 * All rightsreserved. * 文件名称: obj...
  • gmsunyong
  • gmsunyong
  • 2013年04月08日 11:28
  • 1066

第六周任务三

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

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

源代码: #include #include using namespace std; enum SymmetricStyle { axisx,axisy,point};//分别表...
  • pirate_hook
  • pirate_hook
  • 2012年03月27日 18:26
  • 285

Coursera—machine learning(Andrew Ng)第六周编程作业

linearRegCostFunction.m function [J, grad] = linearRegCostFunction(X, y, theta, lambda) %LINEARREGC...
  • ccblogger
  • ccblogger
  • 2017年11月24日 15:33
  • 367

第六周任务三 坐标点

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

【ife】任务十五:零基础JavaScript编码(三)

任务十五:零基础JavaScript编码(三) 北京空气质量:90 上海空气质量:70 天津空气质量:80 广州空气质量:50 深圳空气质量:40 福...
  • zhouziyu2011
  • zhouziyu2011
  • 2016年12月25日 19:26
  • 200
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:第六周 任务三
举报原因:
原因补充:

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