第六周作业 3

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* 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");  
}  


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值