zoukankan      html  css  js  c++  java
  • 第五周项目1-体验常成员函数

    设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等。在设计中,由于求距离、求对称点等操作对原对象不能造成任何改变,所以,将这些函数设计为常成员函数是合适的,能够避免数据成员被无意更改。

    /*
    * Copyright (c) 2015,烟台大学计算机学院
    * All right reserved.
    * 作者:邵帅
    * 文件:Demo.cpp
    * 完成时间:2015年04月08日
    * 版本号:v1.0
    */
    #include <iostream>
    #include <cmath>
    using namespace std;
    class CPoint
    {
    private:
        double x;  // 横坐标
        double y;  // 纵坐标
    public:
        CPoint(double xx=0,double yy=0);
        double Distance1(CPoint p) const; //两点之间的距离(一点是当前点——想到this了吗?,另一点为p)
        double Distance0() const;          // 到原点(0,0)的距离
        CPoint SymmetricAxis(char style) const;//style取'x','y'和'o'分别表示按x轴, y轴, 原点对称
        void input();  //以x,y 形式输入坐标点
        void output(); //以(x,y) 形式输出坐标点
    };
    CPoint::CPoint(double xx,double yy):x(xx),y(yy) {};
    double CPoint::Distance1(CPoint p) const
    {
        double s;
        s=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));
        return s;
    }
    double CPoint::Distance0() const
    {
        return (sqrt(x*x+y*y));
    }
    CPoint CPoint::SymmetricAxis(char style) const
    {
        CPoint p;
        switch (style)
        {
            case 'x':
                p.x=x;
                p.y=-y;break;
            case 'y':
                p.x=-x;
                p.y=y;break;
            case 'o':
                p.x=-x;
                p.y=-y;break;
            default:
                cout<<"Wrong input!"<<endl;
        }
        return p;
    }
    void CPoint::input()
    {
        char ch;
        cout<<"Please input the point(x,y):";
        while(1)
        {
            cin>>x>>ch>>y;
            if (ch==',')
                break;
            cout<<"Wrong style,please input agein."<<endl;
        }
    }
    void CPoint::output()
    {
        cout<<"("<<x<<", "<<y<<")"<<endl;
    }
    
    int main() //测试数据,来自贺老
    {
        double distance;
        CPoint p1,p2,p;
        cout<<"第1个点p1,";
        p1.input();
        cout<<"第2个点p2,";
        p2.input();
        distance=p1.Distance1(p2);
        cout<<"两点的距离为:"<<distance<<endl;
        distance=p1.Distance0();
        cout<<"p1到原点的距离为:"<<distance<<endl;
        p=p1.SymmetricAxis('x');
        cout<<"p1关于x轴的对称点为:";
        p.output();
        p=p1.SymmetricAxis('y');
        cout<<"p1关于y轴的对称点为:";
        p.output();
        p=p1.SymmetricAxis('o');
        cout<<"p1关于原点的对称点为:";
        p.output();
    
        return 0;
    }
    
    
    
    运行结果:


    @ Mayuko

  • 相关阅读:
    build/envsetup.sh 脚本分析 lunch函数
    DEDE自动审核会员发表的最新文章的修改方法
    php学习笔记(三)――操作符与控制结构
    简单的会话类
    学习PHP几个数学计算的内部函数
    关于gotozf学习笔记(11/08/06 12:07)
    再谈中文分词php类
    原站完整打包PHP+MYSQL,可做仿53客服在线客服系统,多用户多国语言企业版
    白话经典算法系列之二 直接插入排序的三种实现
    php 代码运行时间查看类
  • 原文地址:https://www.cnblogs.com/mayuko/p/4567522.html
Copyright © 2011-2022 走看看