亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

python實現輸入三角形邊長自動作圖求面積案例

瀏覽:18日期:2022-07-30 11:13:41

三角形是個好東西,比如知道三條邊邊長,可以判斷能不能組成三角形(兩邊之和大于第三邊),如果可以就進一步計算其面積(海倫公式),最后還能把這個三角形畫出來(余弦定理求角度),所以說這個作為一個編程題目用于教學是比較棒的。

在jupyterlab中運行效果如下:

python實現輸入三角形邊長自動作圖求面積案例

python源代碼如下:

# %matplotlib inline# 建議在jupyterlab中運行 import mathimport numpy as npimport 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 mathclass 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實現輸入三角形邊長自動作圖求面積案例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 天堂精品 | 男女啪啪成人免费网站 | 久久久久免费视频 | 97中文在线 | 国产毛片在线高清视频 | 91精品在线免费观看 | 久久精品一区二区三区四区 | 日本一卡2卡三卡4卡 免费网站仙踪 | 免费高清特级毛片 | 中文字幕日本在线视频二区 | 国产只有精品 | 欧美一级毛片视频 | 精品国产一二三区 | 免费高清欧美一区二区视频 | 日韩在线高清 | 香蕉视频高清 | 国产精品乱码在线观看 | 亚洲欧美影视 | 欧美一级一毛片 | www.香蕉视频.com | 久久亚洲国产的中文 | 欧美成人免费全部观看天天性色 | 日本高清色图 | 99久久综合狠狠综合久久男同 | 亚洲欧美精品日韩欧美 | 亚洲欧美一区二区三区久本道 | 国产短视频精品区第一页 | 亚洲欧美日韩激情在线观看 | 观看麻豆影视文化有限公司 | 亚洲激情视频图片 | 一级女性全黄生活片看看 | 精品欧美一区二区在线观看 | 日韩特黄| 久久精品一区二区三区不卡牛牛 | 欧美日韩午夜精品不卡综合 | 久久精品国产99久久6动漫欧 | 日韩免费无砖专区2020狼 | 麻豆国内精品久久久久久 | 91蝌蚪视频在线观看 | 亚洲国产精品久久人人爱 | 中文字幕在线播放视频 |