关于#c++#的问题:定义平面上的一个Circle类,并在类外设计两个普通函数,主函数构造三个对象进行测试。

定义平面上的一个Circle类,其属性为圆心的点坐标(x,y)和半径(radius),成员函数getArea()计算圆的面积;
类外设计一个普通函数,比较三个圆面积的大小,按照由小到大顺序输出三个圆的面积。
类外再设计一个普通函数,根据圆心横坐标x大小进行排序。
主函数构造三个对象进行测试。

#include <iostream>
#include <cmath>
#include <vector>
#include <algorithm>
using namespace std;

class Circle
{
public:
    Circle(double x=0, double y=0, double r=0):x(x),y(y),radius(r){}
    double getArea()
    {
        return M_PI*radius*radius;
    }
    double getX()
    {
        return x;
    }
private:
    double x;
    double y;
    double radius;
};

void sortByArea(Circle &circle1, Circle &circle2, Circle &circle3)
{
    vector<double> areas = {circle1.getArea(), circle2.getArea(), circle3.getArea()};
    sort(areas.begin(), areas.end());
    for (auto it = areas.begin(); it!=areas.end(); ++it)
        cout << *it << " ";
    cout<<endl;
}

void sortByX(Circle &circle1, Circle &circle2, Circle &circle3)
{
    vector<double> Xs = {circle1.getX(), circle2.getX(), circle3.getX()};
    sort(Xs.begin(), Xs.end());
    for (auto it = Xs.begin(); it!=Xs.end(); ++it)
        cout << *it << " ";
    cout<<endl;
}

int main()
{
    Circle circle1(1.0, 2.4, 2.2);
    Circle circle2(3.1, 0.8, 3.0);
    Circle circle3(1.7, -0.4, 4.6);

    sortByArea(circle1, circle2, circle3);
    sortByX(circle1, circle2, circle3);
    
    return 0;
}