OJ 1393 Problem E 立体空间中的点(II)

Description

设计一个平面上的点Point类和3维的点Point_3D类,满足Point_3D类继承自Point类,用于读取输入的数据,输出所构造的两种点的坐标。
设计Point类需支持一下操作: Point::Point()无参构造。
Point::Point(double,double)两个坐标参数构造。 Point::showPoint()按格式输出Point对象
设计Point_3D类需支持一下操作: Point_3D::Point_3D()无参构造。
Point_3D::Point_3D(double,double,double)三个坐标参数构造。
Point_3D::showPoint()按格式输出Point_3D对象。
----------------------------------------------------------------------------- 你设计Point类和Point_3D类,使得main()函数能够正确运行。 函数调用格式见append.cc。
append.cc中已给出main()函数。

Input

输入的第一个整数n,表示有n组测试数据,后面的输入每行为一组测试数据。每组测试数据的第一行是一个整数m,m有两种取值:2、3;m为2时,后面有两个浮点数x、y,表示一个平面上的点的坐标(x,y);m为3时后面有3个浮点数x、y、z,表示一个3维的点的坐标(x,y,z)。

Output

每组测试数据对应一行输出。
若输入为平面上的点,则输出:“2D Point (x,y)”,x和y为输入的坐标值。
若输入为3维的点,则输出:“3D Point (x,y,y)”,x、y和z为输入的坐标值。

Sample Input

5
3 1 2 3
3 0 0 0
2 -1 1
3 -1 -1 -1
2 0 0

Sample Output

3D Point (1,2,3)
3D Point (0,0,0)
2D Point (-1,1)
3D Point (-1,-1,-1)
2D Point (0,0)

HINT

Append Code

int main()
{
    int cases;
    cin>>cases;
    for(int i = 1; i <= cases; i++)
    {
        double x, y, z;
        int point_type;
        cin>>point_type;
        if(point_type == 2)
        {
            cin>>x>>y;
            Point p(x, y);
            p.showPoint();
        }
        if(point_type == 3)
        {
            cin>>x>>y>>z;
            Point_3D p(x, y, z);
            p.showPoint();
        }
    }
}

Accepted Code

#include <iostream>
using namespace std;

class Point {
protected:
    double x_1, y_1;
    static int num;
public:
    Point(double x1 = 0, double y1 = 0) : x_1(x1), y_1(y1) { num++; }
    void showPoint() { cout << "2D Point (" << x_1 << "," << y_1 << ")\n"; }
    double x() { return x_1; }
    double y() { return y_1; }
    Point& x(int x1) { x_1 = x1; return *this; }
    Point& y(int y1) { y_1 = y1; return *this; }
    static int showNumber() { return num; }
    ~Point() { }
};
class Point_3D : public Point {
private:
    double z_1;
    static int num1;
public:
    Point_3D(double x1 = 0, double y1 = 0, double z1 = 0) : Point(x1, y1) , z_1(z1) { num1++; }
    void showPoint() { cout << "3D Point (" << x_1 << "," << y_1 << "," << z_1 << ")\n"; }
    double z() { return z_1; }
    Point_3D& z(int z1) { z_1 = z1; return *this;}
    Point_3D& setPoint(double x1, double y1, double z1) { x_1 = x1; y_1 = y1; z_1 = z1; return * this;}
    ~Point_3D() { }
    static int showNumber() { return num1; }
};
int Point:: num = 0;
int Point_3D::num1 = 0;

int main()
{
    cout<<"Invariable test output :"<<endl;
    Point_3D p3d;
    p3d.setPoint(-100, 0, 100);
    p3d.showPoint();
    p3d.x(0);
    p3d.y(100);
    cout<<"Point ("<<p3d.x()<<","<<p3d.y()<<","<<p3d.z()<<")"<<endl;
    cout<<"\nTest data output :"<<endl;
    int cases;
    cin>>cases;
    for(int i = 1; i <= cases; i++)
    {
        double x, y, z;
        int point_type;
        cin>>point_type;
        if(point_type == 2)
        {
            cin>>x>>y;
            Point p(x, y);
            p.showPoint();
        }
        if(point_type == 3)
        {
            cin>>x>>y>>z;
            Point_3D p(x, y, z);
            p.showPoint();
        }
    }
    cout<<"Number of 2D Points : "<<Point::showNumber() - Point_3D::showNumber()<<endl;
    cout<<"Number of 3D Points : "<<Point_3D::showNumber() - 1<<endl;
}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值