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

相关推荐
清铎14 分钟前
leetcode_day12_滑动窗口_《绝境求生》
python·算法·leetcode·动态规划
linweidong19 分钟前
嵌入式电机:如何在低速和高负载状态下保持FOC(Field-Oriented Control)算法的电流控制稳定?
stm32·单片机·算法
ai_top_trends27 分钟前
2026 年工作计划 PPT 横评:AI 自动生成的优劣分析
人工智能·python·powerpoint
你怎么知道我是队长31 分钟前
C语言---输入和输出
c语言·开发语言
net3m3334 分钟前
单片机屏幕多级菜单系统之当前屏幕号+屏幕菜单当前深度 机制
c语言·c++·算法
mmz120735 分钟前
二分查找(c++)
开发语言·c++·算法
TDengine (老段)36 分钟前
TDengine Python 连接器进阶指南
大数据·数据库·python·物联网·时序数据库·tdengine·涛思数据
你怎么知道我是队长41 分钟前
C语言---文件读写
java·c语言·开发语言
陌路2042 分钟前
C++30 STL容器 -deque双端队列
开发语言·c++
Insight1 小时前
拒绝手动 Copy!一文吃透 PyTorch/NumPy 中的广播机制 (Broadcasting)
算法