やあみんな私はヘロンの公式、すなわちarea = sqrt(s(s-l1)(s-l2)(s-l3))を使用して三角形の面積を見つけようとしています。このために、与えられた辺が私が持っている三角形に追加されるかどうかを確認する必要があります。
ただし、ここでは、継承されたクラスでこれを使用する方法を理解できません。
私がやりたいのは、親クラスから入力を受け取り、継承されたクラスから面積を計算することです。どんな助けでも大歓迎です。
命名法が使用1)L1、L2、L3:両側2)三角形のChecktriの方法は、所与の辺が3三角形まで追加したりしない場合)を確認するために使用されるAreatriがの継承クラスであるTriangledim面積の必要性が判明される、請求
import math
class Triangledim:
def __init__(self, l1, l2, l3):
self.l1 = l1
self.l2 = l2
self.l3 = l3
#Check if the given measurements form a triangle
def checktri(self):
if (self.l1+self.l2>self.l3) & (self.l2+self.l3>self.l1) & (self.l1+self.l3>self.l2):
s = (self.l1 +self.l2+self.l3)/2
return ("Perimeter of the triangle is %f" %s)
else :
return("not the right triangle proportions")
class Areatri(Triangledim):
def __init__(self):
Triangledim.__init__(self)
area = math.sqrt(self.s(self.s-self.l1)(self.s-self.l2)(self.s-self.l3))
return area
p=Triangledim(7,5,10)
次のコードは、おそらく必要なものです。
import math
class Triangledim():
def __init__(self, l1, l2, l3):
self.l1 = l1
self.l2 = l2
self.l3 = l3
self.s = (self.l1+self.l2+self.l3) / 2.0
def checktri(self):
if (self.l1+self.l2>self.l3) and (self.l2+self.l3>self.l1) and (self.l1+self.l3>self.l2):
print("Perimeter of the triangle is: {}".format(self.s))
else:
print("not the right triangle proportions")
def findArea(self):
area = math.sqrt(self.s*(self.s-self.l1)*(self.s-self.l2)*(self.s-self.l3))
print("The area of the triangle is: {}".format(area))
if __name__ == "__main__":
p = Triangledim(7,5,10)
p.checktri()
p.findArea()
出力:
Perimeter of the triangle is: 11.0
The area of the triangle is: 16.24807680927192
あなたが遺産を使いたい場合、以下があなたのために仕事をします:
import math
class Triangledim():
def __init__(self, l1, l2, l3):
self.l1 = l1
self.l2 = l2
self.l3 = l3
self.s = (self.l1+self.l2+self.l3) / 2.0
def checktri(self):
if (self.l1+self.l2>self.l3) and (self.l2+self.l3>self.l1) and (self.l1+self.l3>self.l2):
print("Perimeter of the triangle is: {}".format(self.s))
else:
print("not the right triangle proportions")
class Areatri(Triangledim):
def findArea(self):
area = math.sqrt(self.s*(self.s-self.l1)*(self.s-self.l2)*(self.s-self.l3))
print("The area of the triangle is: {}".format(area))
if __name__ == "__main__":
p = Areatri(7,5,10)
p.checktri()
p.findArea()
出力:
Perimeter of the triangle is: 11.0
The area of the triangle is: 16.24807680927192
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加