中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

python實現輸入三角形邊長自動作圖求面積的方法-創(chuàng)新互聯

這篇文章主要講解了python實現輸入三角形邊長自動作圖求面積的方法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

創(chuàng)新互聯建站長期為上1000+客戶提供的網站建設服務,團隊從業(yè)經驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯網生態(tài)環(huán)境。為鄂托克企業(yè)提供專業(yè)的成都網站設計、做網站、成都外貿網站建設公司鄂托克網站改版等技術服務。擁有10年豐富建站經驗和眾多成功案例,為您定制開發(fā)。

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

在jupyterlab中運行效果如下:

python實現輸入三角形邊長自動作圖求面積的方法

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()

另外有需要云服務器可以了解下創(chuàng)新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

網頁名稱:python實現輸入三角形邊長自動作圖求面積的方法-創(chuàng)新互聯
標題來源:http://www.rwnh.cn/article20/ceccco.html

成都網站建設公司_創(chuàng)新互聯,為您提供域名注冊、手機網站建設標簽優(yōu)化、網站導航電子商務、全網營銷推廣

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

手機網站建設
夹江县| 新和县| 绥阳县| 洛扎县| 沅江市| 彭阳县| 寿光市| 稷山县| 斗六市| 乐业县| 九龙县| 永新县| 甘谷县| 广饶县| 大足县| 松原市| 贵溪市| 博罗县| 竹山县| 格尔木市| 资溪县| 冷水江市| 麻城市| 扶沟县| 若羌县| 荔浦县| 阿荣旗| 武宣县| 龙口市| 吕梁市| 嘉兴市| 晋中市| 台湾省| 诸城市| 新野县| 浑源县| 邓州市| 门头沟区| 临泽县| 石楼县| 游戏|