Problem D: 平面上的点——Point类 (IV)
来源:互联网 发布:量化投资python为工具 编辑:程序博客网 时间:2024/06/05 15:27
Problem D: 平面上的点——Point类 (IV)
Time Limit: 1 Sec Memory Limit: 4 MBSubmit: 5400 Solved: 3167
[Submit][Status][Web Board]
Description
在数学上,平面直角坐标系上的点用X轴和Y轴上的两个坐标值唯一确定。现在我们封装一个“Point类”来实现平面上的点的操作。
根据“append.cc”,完成Point类的构造方法和show()、showCounter()、showSumOfPoint()方法;实现showPoint()函数。
接口描述:
showPoint()函数:按输出格式输出Point对象,调用Point::show()方法实现。
Point::show()方法:按输出格式输出Point对象。
Point::showCounter()方法:按格式输出当前程序中Point对象的计数。
Point::showSumOfPoint()方法:按格式输出程序运行至当前存在过的Point对象总数。
Input
输入多行,每行为一组坐标“x,y”,表示点的x坐标和y坐标,x和y的值都在double数据范围内。
Output
对每个Point对象,调用show()方法输出其值,或者用showPoint()函数来输出(通过参数传入的)Point对象的值:X坐标在前,Y坐标在后,Y坐标前面多输出一个空格。每个坐标的输出精度为最长16位。调用用showCounter()方法和showSumOfPoint()输出Point对象的计数统计,输出格式见sample。
C语言的输入输出被禁用。
Sample Input
1,23,32,1
Sample Output
Point : (1, 2)Current : 2 points.Point : (3, 3)Current : 2 points.Point : (2, 1)Current : 2 points.In total : 4 points.Current : 3 points.Point : (0, 0)Point : (1, 1)Point : (0, 0)In total : 6 points.
HINT
对象计数通过静态成员来实现
Append Code
append.cc,
All Copyright Reserved 2010-2011 SDUSTOJ TEAM
GPL2.0 2003-2011HUSTOJ Project TEAM
Anything about the Problems, Please Contact Admin:admin
#include <iostream>#include <iomanip> using namespace std;class Point{private: double x,y; static int sum,num;public: Point():x(0),y(0){num++;sum++;} Point(double a):x(a),y(1){num++;sum++;} Point(double a,double b):x(a),y(b){num++;sum++;} Point(const Point&p){x=p.x;y=p.y;num++;sum++;} ~Point(){num--;} void show(){cout<<setprecision(16)<<"Point : ("<<x<<", "<<y<<")"<<endl;} static void showCounter(){cout<<setprecision(16)<<"Current : "<<num<<" points."<<endl;} static void showSumOfPoint(){cout<<setprecision(16)<<"In total : "<<sum<<" points."<<endl;}};void showPoint(Point &a,Point &b,Point &c){a.show();b.show();c.show();}int Point::sum=0;int Point::num=0;int main(){ char c; double a, b; Point q; while(std::cin>>a>>c>>b) { Point p(a, b); p.show(); p.showCounter(); } q.showSumOfPoint(); Point q1(q), q2(1); Point::showCounter(); showPoint(q1, q2, q); Point::showSumOfPoint();}
0 0
- Problem D: 平面上的点和线——Point类、Line类 (IV)
- Problem D: 平面上的点——Point类 (IV)
- Problem H: 平面上的点和线——Point类、Line类 (IV)
- Problem C: 平面上的点和线——Point类、Line类 (IV)
- Problem : 平面上的点和线——Point类、Line类 (IV)
- Problem C: 平面上的点和线——Point类、Line类 (IV)
- Problem C: 平面上的点和线——Point类、Line类 (IV)
- Problem B: 平面上的点——Point类 (IV)
- Problem D: 平面上的点和线——Point类、Line类 (V)
- Problem D: 平面上的点和线——Point类、Line类 (V)
- Problem D: 平面上的点和线——Point类、Line类 (V)
- Problem D: 平面上的点——Point类 (I)
- Problem I: 平面上的点和线——Point类、Line类 (V)
- Problem G: 平面上的点和线——Point类、Line类 (III)
- Problem A: 平面上的点和线——Point类、Line类 (I)
- Problem B: 平面上的点和线——Point类、Line类 (II)
- Problem C: 平面上的点和线——Point类、Line类 (III)
- Problem E: 平面上的点和线——Point类、Line类 (V)
- Supervisor的安装与使用
- Problem B: 平面上的点——Point类 (II)
- BZOJ 2648 SJY摆棋子 K-D Tree
- NYOJ 304 DP
- Problem C: 平面上的点——Point类 (III)
- Problem D: 平面上的点——Point类 (IV)
- 存储过程 --- 2 --- 结合代码案例
- Problem E: 平面上的点——Point类 (V)
- Problem F: 平面上的点——Point类 (VI)
- Problem A: 类的初体验
- JAVA的静态绑定与动态绑定
- Problem B: 类的初体验(II)
- Problem C: 类的初体验(III)
- Problem C: 分数类的输出