洛谷题单1-P5708 【深基2.习2】三角形面积-python-流程图重构

题目描述

一个三角形的三边长分别是 a a a、 b b b、 c c c,那么它的面积为 p ( p − a ) ( p − b ) ( p − c ) \sqrt{p(p-a)(p-b)(p-c)} p(p−a)(p−b)(p−c) ,其中 p = 1 2 ( a + b + c ) p=\frac{1}{2}(a+b+c) p=21(a+b+c)。输入这三个数字,计算三角形的面积,四舍五入精确到 1 1 1 位小数。

输入格式

第一行输入三个实数 a , b , c a,b,c a,b,c,以空格隔开。

输出格式

输出一个实数,表示三角形面积。精确到小数点后 1 1 1 位。

输入输出样例

输入

复制代码
3 4 5

输出

复制代码
6.0

说明/提示

数据保证能构成三角形, 0 ≤ a , b , c ≤ 1000 0\leq a,b,c\leq 1000 0≤a,b,c≤1000,每个边长输入时不超过 2 2 2 位小数。

方式-计算

代码

python 复制代码
class Solution:
    @staticmethod
    def oi_input():
        """从标准输入读取数据"""
        num1, num2, num3 = map(float, input().split())
        return num1, num2, num3

    @staticmethod
    def oi_test():
        """提供测试数据"""
        return 3, 4, 5

    @staticmethod
    def solution(num1, num2, num3):
        num_p = (num1 + num2 + num3) / 2

        print(f'{(num_p * (num_p - num1) * (num_p - num2) * (num_p - num3)) ** 0.5:.1f}')

oi_input = Solution.oi_input
oi_test = Solution.oi_test
solution = Solution.solution

if __name__ == '__main__':
    num1, num2, num3 = oi_test()
    # num1, num2, num3 = oi_input()
    solution(num1, num2, num3)

流程图

海伦公式计算 计算半周长
num_p = (num1+num2+num3)/2 调用 solution(num1, num2, num3) 直接计算面积值
area = [num_p*(num_p-num1)*(num_p-num2)*(num_p-num3)] ** 0.5 格式化输出
print(f'{area:.1f}') 开始 主函数 调用 oi_input() 读取输入数据
num1,num2,num3 = map(float, input().split()) 结束

相关推荐
WindSearcher11 分钟前
大模型微调相关知识
后端·算法
Humbunklung15 分钟前
PySide6 GUI 学习笔记——常用类及控件使用方法(多行文本控件QTextEdit)
笔记·python·学习·pyqt
取酒鱼食--【余九】22 分钟前
rl_sar实现sim2real的整体思路
人工智能·笔记·算法·rl_sar
火车叼位44 分钟前
使用 uv 工具在 Windows 系统快速下载安装与切换 Python
python
西北大程序猿1 小时前
单例模式与锁(死锁)
linux·开发语言·c++·单例模式
你不是我我1 小时前
【Java开发日记】说一说 SpringBoot 中 CommandLineRunner
java·开发语言·spring boot
心扬1 小时前
python网络编程
开发语言·网络·python·tcp/ip
忧陌6061 小时前
DAY 44 预训练模型
python
qq_454175791 小时前
c++学习-this指针
开发语言·c++·学习
点云SLAM1 小时前
PyTorch 中contiguous函数使用详解和代码演示
人工智能·pytorch·python·3d深度学习·contiguous函数·张量内存布局优化·张量操作