第六周作业 3
来源:互联网 发布:java hadoop开发 编辑:程序博客网 时间:2024/04/27 22:49
/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:
* 作 者: 孙建朋
* 完成日期: 2012 年 3 月 28 日
* 版 本 号: 2012032803
* 对任务及求解方法的描述部分
* 输入描述:
* 问题描述:计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等
* 程序输出:
* 程序头部的注释结束
*/
#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!=',') { cout<<"输入格式不对,请重新输入:"<<endl; } else break; } } // 输出坐标点 void CPoint::output() { cout<<"("<<x<<", "<<y<<")"<<endl; } // 求两点之间的距离 double CPoint::Distance(CPoint p) const { return sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y)); } // 求点到原点的距离 double CPoint::Distance0() const { double d; d=sqrt(x*x+y*y); return d; } // 求对称点 CPoint CPoint::SymmetricAxis(SymmetricStyle style) const { CPoint p(x,y);//先指定一个点 switch(style) { case axisx: //关于X轴对称 p.y=-y; break; case axisy: //关于y轴对称 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"); }
- 第六周作业 3
- 第六周作业
- 第六周作业
- 第六周作业 4
- 第六周作业 5
- 第六周作业
- 第六周作业
- 第六周作业
- Java第六周作业
- 第六周作业
- 第六周作业1
- 第六周作业
- 第六周作业
- 第六周作业
- 第六周作业
- 第六周作业
- 第六周作业
- 第六周作业!
- Convention插件
- 算法数据结构试题——在数组中找出已知和的组成数
- 教你如何迅速秒杀掉:99%的海量数据处理面试题
- hdoj2602
- 你应该掌握的——树和二叉树
- 第六周作业 3
- What:由函数Uri.parse()想到的
- Android笔记34:命令行打包编译.apk 包含第三方.jar 的方法
- 设计平面坐标点类
- 第六周任务一
- 解析一下这个makefile
- 第六周任务三
- error LNK2005 已经在***.obj中定义
- A*算法笔记(转)