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


猜你喜欢
- 1.最小界面组成# 导入tkinter模块import tkinter# 创建主窗口对象root = tkinter.Tk()# 设置窗口大
- PHP程序员玩转Linux系列文章:1.PHP程序员玩转Linux系列-怎么安装使用CentOS2.PHP程序员玩转Linux系列-lnmp
- SQL查询某字段的值为空sql中字段的默认有NULL和另一种空白的形式如何取查询这两种存在的记录呢?空白值查询:SELECT * FROM
- 为庆祝jQuery的四周年生日,jQuery官方团队正式发布了jQuery 1.4版本。在这个版本中,jQuery官方团队做了大量的编码、测
- 目录 一、前言1.1 什么是 import 机制?1.2 import 是如何执行的?二、import 机制概览三、import
- 有些时候需要动态加载javascript事件的一些方法往往我们需要在 JS 中动态添加事件,这就涉及到浏览器兼容性问题了,以下谈及的几种方法
- 在app挂载的div同级处写一个加载动画,例如:<body class="font-hei">
- 应用一:有时候我们想把一个 list 或者 dict 传递给 javascript,处理后显示到网页上,比如要用 js 进行可视化的数据。请
- 本篇文章将通过图片对比的方法检查视频中的动态物体,并将其中会动的物体定位用cv2矩形框圈出来。本次项目可用于树莓派或者单片机追踪做一些思路参
- 安装时建议你为MySQL管理创建一个用户和组。由该组用户运行mysql服务器并执行管理任务。(也可以以root身份运行服务器,但是不推荐)第
- 目录前言1. 使用 for...of 遍历普通对象2. 普通对象与 Map 对象相互转换总结参考前言平时我们经常会用到 Object 类上的
- 理由:jquery简单,兼容性好且容易封装。废话不多说,马上开始我们的Jquery插件编写吧。应该有很多人写过类似的插件,我也是有些模仿fl
- 在 HTML 中,有两种方式来表现文本框:一种是使用<input>元素的单行文本框,另一种是使用 <textarea>
- 一、引入方式from itertools import cycle二、使用方法我们先来看看它的源码cycle它接收一个可迭代对象,可以将一个
- 方法一、使用在父模板中使用{include file="child.tpl"}直接将子模板包含进来优点:1、有利于模块的
- 开发环境与配置win_x64Ubuntu14.04Python3.xpip安装pymysql模块直接使用pip安装 pip install
- 利用requests、BeautifulSoup、xlwings库抓取中国银行外汇牌价首页数据1. 利用requests、Beautiful
- 本文实例讲述了Python实现连接两个无规则列表后删除重复元素并升序排序的方法。分享给大家供大家参考,具体如下:# -*- coding:u
- 今天的这篇文章呢,小编来介绍一下如何通过Python来创建各种形式的文件,这里包括了文本文件CSV文件Excel文件压缩文件XML文件JSO
- 使用场景批量合并相同格式的Exce,给DataFrame添加行,给DataFrame添加列使用说明:1.使用某种合并方式(inner/out