c++作业1-F(1126)平面上的点——Point类 (VI)

这是一个关于编程的任务,要求实现一个名为Point的类,用于表示平面上的点。类应包含各种方法,如设置和获取坐标、交换坐标、复制点、判断点是否相等等。输入是多组坐标,输出是按照特定格式展示点的信息和统计信息。示例输入和输出展示了如何使用这个Point类处理不同的坐标情况。
摘要由CSDN通过智能技术生成

Problem F: 平面上的点——Point类 (VI)

Time Limit: 1 Sec  Memory Limit: 4 MB
Submit: 10116  Solved: 4809
[Submit][Status]

Description

在数学上,平面直角坐标系上的点用X轴和Y轴上的两个坐标值唯一确定。现在我们封装一个“Point类”来实现平面上的点的操作。

根据“append.cc”,完成Point类的构造方法和接口描述中的方法和函数。

接口描述:
showPoint()函数:按输出格式输出Point对象。
Point::show()方法:按输出格式输出Point对象。
Point::showSumOfPoint()方法:按格式输出程序运行至当前存在过的Point对象总数。
Point::x()方法:取x坐标。
Point::y()方法:取y坐标。
Point::x(double)方法:传参数设置x坐标并返回。
Point::y(double)方法:传参数设置y坐标并返回。
Point::setPoint(double,double)方法:设置Point对象的x坐标(第一个参数)和y坐标(第二个参数)并返回本对象。
Point::isEqual()方法:判断传入的参数与对象的坐标是否相同,相同返回true。
Point::copy()方法:传参数复制给对象。
Point::inverse()方法,有两个版本:不传参数则将对象自身的x坐标和y坐标互换;若将Point对象做参数传入,则将传入对象的坐标交换复制给对象自身,不修改参数的值。

 

Input

输入多行,每行为一组坐标“x,y”,表示点的x坐标和y坐标,x和y的值都在double数据范围内。

 

Output

用ShowPoint()函数来输出(通过参数传入的)Point对象的值或坐标值:X坐标在前,Y坐标在后,Y坐标前面多输出一个空格。每个坐标的输出精度为最长16位。
对每个Point对象,调用show()方法输出其值,输出格式与ShowPoint()函数略有不同:“Point[i] :”,i表示这是程序运行过程中第i个被创建的Point对象。
调用showSumOfPoint()输出Point对象的计数统计,输出格式见sample。

C语言的输入输出被禁用。

 

Sample Input

1,2 3,3 2,1

Sample Output

Point[3] : (1, 2) Point[1] : (2, 1) Point[4] : (3, 3) Point[1] : (3, 3) Point[5] : (1, 2) Point[1] : (1, 2) Point[2] : (0, 0) ==========gorgeous separator========== Point[2] : (-7, 5) Point[3] : (1, 2) Point[4] : (3, 3) Point[5] : (1, 2) Point[6] : (-7, 5) ==========gorgeous separator========== Point[63] : (3, 3) Point : (3, 3) Point : (3, 3) Point : (3, 3) In total : 64 points.

HINT

 

给函数正确的返回值。注意常量对象调用的函数。

 

 

 

Append Code

append.cc,

int main()
{
    int l(0);
    char c;
    double a, b;
    Point p, q, pt[60];
    while(std::cin>>a>>c>>b)
    {
        if(a == b)
            p.copy(pt[l].setPoint(a, b));
        if(a > b)
            p.copy(pt[l].setPoint(a, b).inverse());
        if(a < b)
            p.inverse(pt[l].setPoint(a, b));
        if(a < 0)
            q.copy(p).inverse();
        if(b < 0)
            q.inverse(p).copy(pt[l]);
        pt[l++].show();
        p.show();
    }
    q.show();
    cout<<"==========gorgeous separator=========="<<endl;
    double x(0), y(0);
    for(int i = 0; i < l; i++)
        x += pt[i].x(), y -= pt[i].y();
    pt[l].x(y), pt[l].y(x);
    q.copy(pt[l]).show();
    for(int i = 0; i <= l; i++)
        pt[i].show();
    cout<<"==========gorgeous separator=========="<<endl;
    const Point const_point(3, 3);
    const_point.show();
    for(int i = 0; i <= l; i++)
    {
        if(const_point.isEqual(pt[i]))
        {
            ShowPoint(const_point);
            ShowPoint(const_point.x(), const_point.y());
            ShowPoint(Point(const_point.x(), const_point.y()));
        }
    }
    const_point.showSumOfPoint();
}

答案

#include<iostream>
#include<iomanip>
using namespace std;
class Point
{
private:
    double a,b;
    int m;
    static int n;
public:
    Point():a(0),b(0){++n;m=n;}
    Point(double x,double y):a(x),b(y){++n;m=n;}
    void show()const
    {
        cout<<setprecision(16)<<"Point["<<m<<"] : ("<<a<<", "<<b<<")"<<endl;
    }
    static void showSumOfPoint()
    {
        cout<<"In total : "<<n<<" points."<<endl;
    }
    double x()const {return a;}
    double y()const {return b;}
    double x(double c){a=c;return a;}
    double y(double d){b=d;return b;}
    Point& setPoint(double c,double d)
    {
        a=c;
        b=d;
        return *this;
    }
    bool isEqual(Point& p)const
    {
        if(p.a==a&&p.b==b)
            return true;
        else
            return false;
    }
    Point& copy(const Point& p)
    {
        a=p.a;
        b=p.b;
        return *this;
    }
    Point& inverse()
    {
        double t;
        t=a;
        a=b;
        b=t;
        return *this;
    }
     Point& inverse(Point& p)
    {
        a=p.b;
        b=p.a;
        return *this;
    }

};

void ShowPoint(const Point &p)
{
    cout<<setprecision(16)<<"Point : ("<<p.x()<<", "<<p.y()<<")"<<endl;
}
void ShowPoint(double x,double y)
{
    cout<<setprecision(16)<<"Point : ("<<x<<", "<<y<<")"<<endl;
}
void ShowPoint(Point& p,double x,double y)
{
    cout<<setprecision(16)<<"Point : ("<<p.x(x)<<", "<<p.y(y)<<")"<<endl;
}
int Point::n=0;

int main()
{
    int l(0);
    char c;
    double a, b;
    Point p, q, pt[60];
    while(std::cin>>a>>c>>b)
    {
        if(a == b)
            p.copy(pt[l].setPoint(a, b));
        if(a > b)
            p.copy(pt[l].setPoint(a, b).inverse());
        if(a < b)
            p.inverse(pt[l].setPoint(a, b));
        if(a < 0)
            q.copy(p).inverse();
        if(b < 0)
            q.inverse(p).copy(pt[l]);
        pt[l++].show();
        p.show();
    }
    q.show();
    cout<<"==========gorgeous separator=========="<<endl;
    double x(0), y(0);
    for(int i = 0; i < l; i++)
        x += pt[i].x(), y -= pt[i].y();
    pt[l].x(y), pt[l].y(x);
    q.copy(pt[l]).show();
    for(int i = 0; i <= l; i++)
        pt[i].show();
    cout<<"==========gorgeous separator=========="<<endl;
    const Point const_point(3, 3);
    const_point.show();
    for(int i = 0; i <= l; i++)
    {
        if(const_point.isEqual(pt[i]))
        {
            ShowPoint(const_point);
            ShowPoint(const_point.x(), const_point.y());
            ShowPoint(Point(const_point.x(), const_point.y()));
        }
    }
    const_point.showSumOfPoint();
}

分析

9bb16e81358f4a8aad371052b7a850c9.jpeg

4876d6b7d35e46c2b16fac887b5dc7c9.jpeg

2f8730d86a8648d5a91b8aa3cdf7907f.jpeg

4824ceb3afd144ae9c4336cfda62fcdc.jpeg

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值