设计一个平面点类,拥有两个实例属性: 横座标、纵座标: 拥有一个特殊方法 str以及一个普通的实例方法: 计算它与另一个平面点之间的距离。再由平面点类出发,以组合或继承的方式设计一个平面矩形类,拥有两个实例属性: 某条对角线的两个端点: 拥有二 个普通的实例方法: 计算周长、计算面积;别忘了实现它的 _s方法。编写一些简单的测试 代码。
时间: 2024-02-22 14:59:21 浏览: 57
好的,我来实现这个需求。
首先,我们可以定义一个平面点类,如下所示:
```python
class Point:
def __init__(self, x, y):
self.x = x
self.y = y
def __str__(self):
return f"({self.x}, {self.y})"
def distance(self, other):
return ((self.x - other.x) ** 2 + (self.y - other.y) ** 2) ** 0.5
```
在这个类中,我们定义了两个实例属性 `x` 和 `y`,表示平面点的横坐标和纵坐标。我们还定义了一个特殊方法 `__str__`,用于返回平面点的字符串表示。最后,我们定义了一个普通的实例方法 `distance`,用于计算当前平面点与另一个平面点之间的距离。
接下来,我们可以用继承的方式定义一个平面矩形类,如下所示:
```python
class Rectangle:
def __init__(self, p1, p2):
self.p1 = p1
self.p2 = p2
def __str__(self):
return f"({self.p1}, {self.p2})"
def perimeter(self):
length = self.p1.distance(Point(self.p2.x, self.p1.y))
width = self.p1.distance(Point(self.p1.x, self.p2.y))
return 2 * (length + width)
def area(self):
length = self.p1.distance(Point(self.p2.x, self.p1.y))
width = self.p1.distance(Point(self.p1.x, self.p2.y))
return length * width
```
在这个类中,我们定义了两个实例属性 `p1` 和 `p2`,表示平面矩形对角线的两个端点。我们还定义了一个特殊方法 `__str__`,用于返回平面矩形的字符串表示。最后,我们定义了两个普通的实例方法 `perimeter` 和 `area`,用于计算平面矩形的周长和面积。这里需要注意的是,我们在计算周长和面积时,需要分别计算平面矩形的长度和宽度,然后根据公式进行计算。
最后,我们可以编写一些简单的测试代码,如下所示:
```python
# 创建两个平面点
p1 = Point(0, 0)
p2 = Point(3, 4)
# 计算两个平面点之间的距离
print(p1.distance(p2)) # 输出 5.0
# 创建一个平面矩形
r = Rectangle(p1, p2)
# 计算平面矩形的周长和面积
print(r.perimeter()) # 输出 14.0
print(r.area()) # 输出 12.0
```
在这个测试代码中,我们首先创建了两个平面点 `p1` 和 `p2`,然后计算了它们之间的距离。接下来,我们创建了一个平面矩形 `r`,然后分别计算了它的周长和面积,并输出结果。
阅读全文