欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python實現(xiàn)輸入三角形邊長自動作圖求面積案例

 更新時間:2020年04月12日 11:52:59   作者:sheldonxxd  
這篇文章主要介紹了python實現(xiàn)輸入三角形邊長自動作圖求面積案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

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

在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("輸入的邊長無法構(gòu)成三角形")
   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)
  # 最長邊作為底部邊長,最左側(cè)與坐標(biāo)軸原點對齊
  B,C = lines
  # 根據(jù)三邊長求兩個水平夾角角度
  cos_C = (A**2+B**2-C**2)/(2*A*B)
  cos_B = (A**2+C**2-B**2)/(2*A*C)
  # 根據(jù)余弦值求得正切值
  k_C = math.tan(math.acos(cos_C))
  k_B = math.tan(math.acos(cos_B))
  # 根據(jù)正切值和高,獲得邊長
  w_C = height/k_C
  w_B = height/k_B
  # 確定三個頂點的坐標(biāo)
  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) # 保證兩條坐標(biāo)軸scale一致
  plt.axis('off') # 關(guān)閉顯示直角坐標(biāo)系
  plt.savefig("./trianle.png",dpi=300)
  print("三角形面積為:%.4f"%(area))
 
if __name__=="__main__":
 plot_triangle()

補充知識:Python 三角形類,實現(xiàn)數(shù)據(jù)的輸入、輸出、周長、面積的計算

我就廢話不多說了,還是直接看代碼吧!

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("不符合三角邊的規(guī)定,重新輸入!")
        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實現(xiàn)輸入三角形邊長自動作圖求面積案例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python語言快速上手學(xué)習(xí)方法

    Python語言快速上手學(xué)習(xí)方法

    今天小編就為大家分享一篇關(guān)于Python語言快速上手學(xué)習(xí)方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • PyInstaller將Python文件打包為exe后如何反編譯(破解源碼)以及防止反編譯

    PyInstaller將Python文件打包為exe后如何反編譯(破解源碼)以及防止反編譯

    這篇文章主要介紹了PyInstaller將Python文件打包為exe后如何反編譯(破解源碼)以及防止反編譯,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • 詳解Python爬蟲爬取博客園問題列表所有的問題

    詳解Python爬蟲爬取博客園問題列表所有的問題

    這篇文章主要介紹了詳解Python爬蟲爬取博客園問題列表所有的問題,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Django migrate報錯的解決方案

    Django migrate報錯的解決方案

    在講解如何解決migrate報錯原因前,我們先要了解migrate做了什么事情,本文就詳細的介紹migrate使用以及出現(xiàn)問題的解決,感興趣的可以了解一下
    2021-05-05
  • Python3實現(xiàn)抓取javascript動態(tài)生成的html網(wǎng)頁功能示例

    Python3實現(xiàn)抓取javascript動態(tài)生成的html網(wǎng)頁功能示例

    這篇文章主要介紹了Python3實現(xiàn)抓取javascript動態(tài)生成的html網(wǎng)頁功能,結(jié)合實例形式分析了Python3使用selenium庫針對javascript動態(tài)生成的HTML網(wǎng)頁元素進行抓取的相關(guān)操作技巧,需要的朋友可以參考下
    2017-08-08
  • Pyecharts V1和V0.5之間相互切換的方法

    Pyecharts V1和V0.5之間相互切換的方法

    這篇文章主要介紹了Pyecharts V1和V0.5之間相互切換的方法,Pyecharts這個可視化庫火爆,官方如是說:Echarts 是一個由百度開源的數(shù)據(jù)可視化,憑借著良好的交互性,精巧的圖表設(shè)計,得到了眾多開發(fā)者的認可,下面和小編一起進入文章了解具體內(nèi)容吧
    2022-02-02
  • 用scikit-learn和pandas學(xué)習(xí)線性回歸的方法

    用scikit-learn和pandas學(xué)習(xí)線性回歸的方法

    這篇文章主要介紹了用scikit-learn和pandas學(xué)習(xí)線性回歸的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 在pycharm中使用matplotlib.pyplot 繪圖時報錯的解決

    在pycharm中使用matplotlib.pyplot 繪圖時報錯的解決

    這篇文章主要介紹了在pycharm中使用matplotlib.pyplot 繪圖時報錯的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • 解決python多線程報錯:AttributeError: Can''t pickle local object問題

    解決python多線程報錯:AttributeError: Can''t pickle local object問題

    這篇文章主要介紹了解決python多線程報錯:AttributeError: Can't pickle local object問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • python使用pygame框架實現(xiàn)推箱子游戲

    python使用pygame框架實現(xiàn)推箱子游戲

    這篇文章主要為大家詳細介紹了python使用pygame框架實現(xiàn)推箱子游戲,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11

最新評論