python实现输入三角形边长自动作图求面积案例
作者:sheldonxxd 发布时间:2023-08-12 01:47:49
标签:python,三角形,边长,面积
三角形是个好东西,比如知道三条边边长,可以判断能不能组成三角形(两边之和大于第三边),如果可以就进一步计算其面积(海伦公式),最后还能把这个三角形画出来(余弦定理求角度),所以说这个作为一个编程题目用于教学是比较棒的。
在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()
来源:https://blog.csdn.net/sheldonxxd/article/details/96482027
0
投稿
猜你喜欢
- 一、python-yml文件读写使用库 :import yaml安装:pip install pyyaml示例:文件config2.ymlg
- GOPATH设置go 命令依赖一个重要的环境变量:$GOPATH1(注:这个不是Go安装目录。下面以笔者的工作目录为说明,请替换自己机器上的
- 最近从某网站下载了一批文档,但是文件是用数字串命名的文档(很多图书馆都这样吧),现在我也下载完了这些文件,也有这些文件的列表,就是不能一个一
- 由于工作对人的眼球和精神都会带来一定的疲劳,所以在界面设计中,希望用户能够准确的关注重要的信息,而不因为用户的长期使用而流失信息。最近在看《
- RPC是什么?所谓RPC(remote procedure call 远程过程调用)框架实际是提供了一套机制,使得应用程序之间可以进行通信,
- 现在很多朋友都不止一个账户,不止一个密码。忘记账户名、密码,或账户名、密码输入错误也就难免啦。每当这个时候,你是否和我一样会有小小的焦虑产生
- 这段时间在爬取了杭州某网站发布的二手房信息,在作图的时候发现在地图呈现上还是有欠缺,这里就把用到的贴出来,提升一下记忆。之前有接触用Base
- 使用到的库: dlib+Opencv python版本: 3.8 编译环境: Jupyter Notebook (Anaconda3)0.D
- 1、设置无头浏览器模式from selenium import webdriverfrom selenium.webdriver.chrom
- pandas每次多Sheet写入文件,只能一次性存入,不然每次会重写文件,最后只保留最后一次的写入。# !usr/bin env pytho
- 或许现在关心交互设计的设计师们大部分来自于了互联网行业,所以我们看到当你搜索“交互设计”时更多的BLOG和文章是在谈论互联网,网站的导航,注
- 问题:每次打开pycharm打开py文件光标都是insert模式, 像下面图片那样解决方案:讲Tools里面的Vim Emulator勾选去
- MySQL 5.0.16的乱码问题可以用下面的方法解决:1.设置phpMyAdminLanguage:Chinese simplified
- 问题:1.一个销售系统,设有各级代理商,每个代理商的表是这样设计的 数据库结构表1: 代理商资料表[id]
- 现象:已知,连接的WIFI网络需要通过代理服务器才能连接外网,按照正常的程序无法发送邮件,而直连一个没有代理的网络【如自己的wifi热点】,
- 新建label与button,并设置位置(grid)import tkinter as tkroot = tk.Tk()label = tk
- 在 Django 网站中使用 mailgun 的邮件收发服务。1.在 mailgun 官网上注册个账号(免费,免费账号每个月有10000条收
- 直接看代码: 代码如下:Class GoogleTranslator sub Class_Initialize
- 使用命令行时,如果要添加选项的话,python 2.3里新增加了一个模块叫optparse,也是专门来处理命令行选项的。from optpa
- 1. 用Dreamweaver 4.0轻松设计会自动弹性调整的网页 首先需要保证的是你的页面内容采用了表格的格式,然后打开你要编辑的页面,按