/* * Copyright (c) 2015, 烟台大学计算机学院 * All rights reserved. * 文件名称:main.cpp * 作 者 :韩娟 * 完成日期 :2015年6月3日 * 版 本 号 :v1.0 * * 问题描述 : (1)先建立一个Point(点)类,包含数据成员x,y(坐标点); (2)以Point为基类,派生出一个Circle(圆)类,增加数据成员(半径),基类的成员表示圆心; (3)编写上述两类中的构造、析构函数及必要运算符重载函数(本项目主要是输入输出); (4)定义友元函数int locate,判断点p与圆的位置关系(返回值<0圆内,==0圆上,>0 圆外); (5)在圆类上重载关系运算符(6种),使之能够按圆的面积比较两个圆的大小。自编main函数完成测试 * 输入描述 : 略 * 程序输出 :按要求输出 */ #include <iostream> #include<Cmath> using namespace std; class Point { public: Point(double a=0,double b=0):x(a),y(b) {} protected: double x,y; }; class Circle:public Point { public: Circle(double a=0,double b=0,double r=0): Point(a,b),radius(r){} double area ( ) const; friend ostream &operator<<(ostream &,const Circle &); bool operator>(const Circle &); bool operator<(const Circle &); bool operator>=(const Circle &); bool operator<=(const Circle &); bool operator==(const Circle &); bool operator!=(const Circle &); protected: double radius; }; double Circle::area( ) const { return 3.14159*radius*radius; } ostream &operator<<(ostream &output,const Circle &c) { output<<"Center=["<<c.x<<", "<<c.y<<"], r="<<c.radius; return output; } bool Circle::operator>(const Circle &c) { return (this->radius - c.radius) > 1e-7; } bool Circle::operator<(const Circle &c) { return (c.radius - this->radius) > 1e-7; } bool Circle::operator>=(const Circle &c) { return !(*this < c); } bool Circle::operator<=(const Circle &c) { return !(*this > c); } bool Circle::operator==(const Circle &c) { return abs(this->radius - c.radius) < 1e-7; } bool Circle::operator!=(const Circle &c) { return abs(this->radius - c.radius) > 1e-7; } int main( ) { Circle c1(3,2,4),c2(4,5,5); cout<<"圆c1( "<<c1<<" )的面积是 "<<c1.area()<<endl; cout<<"圆c2( "<<c2<<" )的面积是 "<<c2.area()<<endl; cout<<"圆c1 "; if(c1>c2) cout<<"大于, "; if(c1<c2) cout<<"小于, "; if(c1>=c2) cout<<"大于等于, "; if(c1<=c2) cout<<"小于等于, "; if(c1==c2) cout<<"等于, "; if(c1!=c2) cout<<"不等于, "; cout<<"圆c2"<<endl; return 0; }
知识点总结 :
有些上面的知识点要稳固。
学习心得 :
温故而知新。