原题链接:蓝桥杯算法提高VIP-12-1三角形
解题思路:
按照公式计算就可以了。
注意事项:
参考代码:
from math import sqrt
def f(x1,y1,x2,y2,x3,y3):
a = sqrt((x1-x2)**2+(y1-y2)**2)
b = sqrt((x1-x3)**2+(y1-y3)**2)
c = sqrt((x2-x3)**2+(y2-y3)**2)
p = (a+b+c)/2
len = a+b+c #计算周长和面积
area = sqrt(p*(p-a)*(p-b)*(p-c))
A1 = 2*(x2-x1) #计算外心
B1 = 2*(y2-y1)
C1 = x2**2+y2**2-x1**2-y1**2
A2 = 2*(x3-x2)
B2 = 2*(y3-y2)
C2 = x3**2+y3**2-x2**2-y2**2
x_out = ((C1*B2)-(C2*B1))/((A1*B2)-(A2*B1))
y_out = ((A1*C2)-(A2*C1))/((A1*B2)-(A2*B1))
x_weight = (x1+x2+x3)/3 #计算重心
y_weight = (y1+y2+y3)/3
print('%.2f' % len)
print('%.2f' % area)
print('{:.2f} {:.2f}'.format(x_out,y_out))
print('{:.2f} {:.2f}'.format(x_weight,y_weight))
if __name__ == '__main__':
x1,y1 = map(float,input().strip().split())
x2,y2 = map(float,input().strip().split())
x3,y3 = map(float,input().strip().split())
f(x1,y1,x2,y2,x3,y3)0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复