C++定义Point类描述点的坐标,可以输出坐标,可以求两个点之间的距离。 主函数声明Point类数组Point p[5],输入5个点的坐标,根据5个点与原点[0,0]之间的距离,由近至远排序输出距离值。
时间: 2024-02-09 14:11:59 浏览: 87
好的,这是一个典型的面向对象编程问题。
首先,我们需要定义一个 Point 类,用于描述点的坐标和计算两个点之间的距离。下面是 Point 类的一个示例实现:
```cpp
#include <iostream>
#include <cmath>
using namespace std;
class Point {
public:
double x, y;
Point(double _x, double _y) : x(_x), y(_y) {}
double distance() const {
return sqrt(x * x + y * y);
}
double distance(const Point &other) const {
double dx = x - other.x;
double dy = y - other.y;
return sqrt(dx * dx + dy * dy);
}
friend bool operator<(const Point &a, const Point &b) {
return a.distance() < b.distance();
}
friend ostream &operator<<(ostream &out, const Point &p) {
out << "(" << p.x << ", " << p.y << ")";
return out;
}
};
```
在这个实现中,Point 类有两个数据成员 x 和 y,分别表示点的 x 和 y 坐标。它有两个公共方法 distance() 和 distance(const Point &other),用于计算点与原点之间的距离和两个点之间的距离。此外,它还重载了小于运算符 <,用于在排序时比较两个点之间的距离。最后,它还重载了流插入运算符 <<,用于输出点的坐标。
接下来,在主函数中,我们可以声明一个 Point 类型的数组 p,并输入 5 个点的坐标:
```cpp
int main() {
Point p[5] = {
Point(1, 2),
Point(3, 4),
Point(5, 6),
Point(7, 8),
Point(9, 10)
};
// 输入 5 个点的坐标
for (int i = 0; i < 5; i++) {
double x, y;
cout << "请输入第 " << i + 1 << " 个点的坐标(x, y):";
cin >> x >> y;
p[i] = Point(x, y);
}
// 根据距离排序输出
sort(p, p + 5);
for (int i = 0; i < 5; i++) {
cout << "第 " << i + 1 << " 个点的坐标为:" << p[i] << ",距离原点的距离为:" << p[i].distance() << endl;
}
return 0;
}
```
在这个主函数中,我们首先声明了一个 Point 类型的数组 p,然后按照题目要求输入了 5 个点的坐标。最后,我们使用 STL 中的 sort() 函数对 p 数组进行排序,并输出每个点的坐标和距离原点的距离。
完整代码如下:
阅读全文