(程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称: Student.cpp * 作 者: 计114-4 张馨 * 完成日期: 2012年 3 月 28日 * 版 本 号: V 1.0 * 对任务及求解方法的描述部分 * 输入描述: * 问题描述: * 程序输出:按要求输出 * 程序头部的注释结束 */
#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"); }
上级感言:经过老师的讲解还算有点头绪了。。。
09-21
09-21
09-21
09-21
09-21