洛谷题单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()) 结束

相关推荐
360安全应急响应中心3 分钟前
Python代码保护之重置操作码映射的攻与防探究(一)
python·逆向
蓝风破云16 分钟前
C++实现常见的排序算法
数据结构·c++·算法·排序算法·visual studio
码界奇点25 分钟前
Python内置函数全解析:30个核心函数语法、案例与最佳实践指南
linux·服务器·python
dreams_dream43 分钟前
django错误记录
后端·python·django
艾醒1 小时前
大模型面试题剖析:Pre-Norm与Post-Norm的对比及当代大模型选择Pre-Norm的原因
算法
怀旧,1 小时前
【C++】 9. vector
java·c++·算法
Tony Bai1 小时前
泛型重塑 Go 错误检查:errors.As 的下一站 AsA?
开发语言·后端·golang
hixiong1231 小时前
C# 编写一个XmlToDota的转换工具
开发语言·人工智能·yolo·c#
MC皮蛋侠客1 小时前
使用Python实现DLT645-2007智能电表协议
python·网络协议·tcp/ip·能源
中等生1 小时前
Python 的循环引入问题
python