|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
请写出计算三角形面积的函数
代码模板如下
# The three vertices of a triangle
a=np.array([-2,-1])
b=np.array([2,1])
c=np.array([0,3])
print(area(a,b,c))# Implement this function!
要求:1.需要实现的函数名称为area()
2.可以使用NumPy.
本帖最后由 逃兵 于 2020-12-5 17:25 编辑
- import numpy as np
- import math
- a=np.array([-2,-1])
- b=np.array([2,1])
- c=np.array([0,3])
- def area(a,b,c):
- #求边长
- ab = a-b
- lenab = math.hypot(ab[0],ab[1])
- ac = a-c
- lenac = math.hypot(ac[0],ac[1])
- bc = b-c
- lenbc = math.hypot(bc[0],bc[1])
- #求面积
- p = (lenab+lenac+lenbc)/2
- s = (p*(p-lenab)*(p-lenac)*(p-lenbc))**0.5
- return s
- print(area(a,b,c))
复制代码
或者
- import numpy as np
- a=np.array([-2,-1])
- b=np.array([2,1])
- c=np.array([0,3])
- def area(a,b,c):
- #求边长
- ab = a-b
- lenab = np.sqrt(np.square(ab[0])+np.square(ab[1]))
- ac = a-c
- lenac = np.sqrt(np.square(ac[0])+np.square(ac[1]))
- bc = b-c
- lenbc = np.sqrt(np.square(bc[0])+np.square(bc[1]))
- #求面积
- p = (lenab+lenac+lenbc)/2
- s = (p*(p-lenab)*(p-lenac)*(p-lenbc))**0.5
- return s
- print(area(a,b,c))
复制代码
|
|