圆月山庄资源网 Design By www.vgjia.com
三角形是个好东西,比如知道三条边边长,可以判断能不能组成三角形(两边之和大于第三边),如果可以就进一步计算其面积(海伦公式),最后还能把这个三角形画出来(余弦定理求角度),所以说这个作为一个编程题目用于教学是比较棒的。
在jupyterlab中运行效果如下:
python源代码如下:
# %matplotlib inline # 建议在jupyterlab中运行 import math import numpy as np import matplotlib.pyplot as plt def judge(lines): """判断是否能组成三角形""" flag = 0 for i in range(3): l1 = lines.copy() # 要copy,不然会对源进行修改 r = l1.pop(i) # r被取出,l1剩余俩 if (r>=sum(l1)): print("输入的边长无法构成三角形") break else: flag += 1 continue if flag==3: return True else: return False def plot_triangle(): lines = input("输入三条边长并用空格隔开:") params = lines.split(" ") lines = list(map(lambda x:float(x),params)) if judge(lines): p = sum(lines)/2 a,b,c = lines area = math.sqrt(p*(p-a)*(p-b)*(p-c)) width = max(lines) height = area/width*2 # 计算角度 lines = [a,b,c] idx_A = np.argmax(lines) A = lines.pop(idx_A) # 最长边作为底部边长,最左侧与坐标轴原点对齐 B,C = lines # 根据三边长求两个水平夹角角度 cos_C = (A**2+B**2-C**2)/(2*A*B) cos_B = (A**2+C**2-B**2)/(2*A*C) # 根据余弦值求得正切值 k_C = math.tan(math.acos(cos_C)) k_B = math.tan(math.acos(cos_B)) # 根据正切值和高,获得边长 w_C = height/k_C w_B = height/k_B # 确定三个顶点的坐标 loc_A = (0,height) loc_B = (-w_B,0) loc_C = (w_C,0) plt.figure(figsize=(4,3)) plt.plot([0,-w_B,w_C,0],[height,0,0,height],"gray") plt.plot([0,0],[0,height],"r--") plt.text(1,height/2,"h=%.1f"%(height),color="blue",fontsize=12) ax = plt.gca() ax.set_aspect(1) # 保证两条坐标轴scale一致 plt.axis('off') # 关闭显示直角坐标系 plt.savefig("./trianle.png",dpi=300) print("三角形面积为:%.4f"%(area)) if __name__=="__main__": plot_triangle()
补充知识:Python 三角形类,实现数据的输入、输出、周长、面积的计算
我就废话不多说了,还是直接看代码吧!
import math class Triangle: def __init__(self): a=0 b=0 c=0 def add(self): self.a=int(input("输入第1条边的长度:")) self.b=int(input("输入第2条边的长度:")) self.c=int(input("输入第3条边的长度:")) while (self.a+self.b<=self.c): print("不符合三角边的规定,重新输入!") self.a=int(input("输入第1条边的长度:")) self.b=int(input("输入第2条边的长度:")) self.c=int(input("输入第3条边的长度:")) def out(self): print (self.a,self.b,self.c) def length(self): print (self.a+self.b+self.c) def area(self): print ((((a+b+c)/2)-a)*(((a+b+c)/2)-b)*(((a+b+c)/2)-c)*((a+b+c)/2)) t=Triangle() t.add() t.out() t.length() t.area()
以上这篇python实现输入三角形边长自动作图求面积案例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月02日
2024年11月02日
- 完美倒立.2024-夜色碳酸【草台回声】【FLAC分轨】
- 杨青《半山听雨贰HQ》头版限量编号[低速原抓WAV+CUE]
- 白玛多吉《云上西藏1+2》DTS-WAV
- 模拟之声慢刻CD《柏林之声3》[正版CD原抓WAV+CUE]
- 威神V(WayV)《The Highest》[FLAC/分轨][259.1MB]
- 余超颖《迷焕纪》[320K/MP3][201.15MB]
- 余超颖《迷焕纪》[FLAC/分轨][784.22MB]
- 温岚.2005-爱回温新歌加精选2CD【阿尔发】【WAV+CUE】
- 尤雅.1990-台语怀念金曲特选辑【太阳神】【WAV+CUE】
- 群星.2024-七夜雪电视剧影视原声带【听见时代】【FLAC分轨】
- 群星《胎教音乐 古典钢琴曲与水晶摇篮曲》[320K/MP3][134.14MB]
- 群星《胎教音乐 古典钢琴曲与水晶摇篮曲》[FLAC/分轨][654.13MB]
- 许惠钧《睡眠钢琴与校园民歌金曲 空灵新世纪催眠曲》[320K/MP3][201.15MB]
- wbg战队国籍分别都是哪里的 wbg战队2024阵容国籍介绍
- wbg战队教练是韩国人吗 s14wbg战队教练国籍介绍