洛谷题单2-P5717 【深基3.习8】三角形分类-python-流程图重构

题目描述

给出三条线段 a , b , c a,b,c a,b,c 的长度,均是不大于 10000 10000 10000 的正整数。打算把这三条线段拼成一个三角形,它可以是什么三角形呢?

  • 如果三条线段不能组成一个三角形,输出Not triangle
  • 如果是直角三角形,输出Right triangle
  • 如果是锐角三角形,输出Acute triangle
  • 如果是钝角三角形,输出Obtuse triangle
  • 如果是等腰三角形,输出Isosceles triangle
  • 如果是等边三角形,输出Equilateral triangle

如果这个三角形符合以上多个条件,请按以上顺序分别输出,并用换行符隔开。

输入格式

输入 3 个整数 a a a、 b b b 和 c c c。

输出格式

输出若干行判定字符串。

输入输出样例

输入

复制代码
3 3 3

输出

复制代码
Acute triangle
Isosceles triangle
Equilateral triangle

方式

代码

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

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

    @staticmethod
    def solution(sides):
        sides.sort()

        a, b, c = sides[0], sides[1], sides[2]

        if a + b <= c or a + c <= b or b + c <= a:
            print("Not triangle")
        else:
            if sides[0] ** 2 + sides[1] ** 2 == c ** 2:
                print("Right triangle")
            elif sides[0] ** 2 + sides[1] ** 2 > c ** 2:
                print("Acute triangle")
            else:
                print("Obtuse triangle")

            if a == b or a == c or b == c:
                print("Isosceles triangle")

            if a == b == c:
                print("Equilateral triangle")


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

if __name__ == '__main__':
    sides = oi_test()
    # sides = oi_input()
    solution(sides)

流程图

特殊类型判断 类型判断 否 是 是 否 是 否 是 否 是 否 是否有两边相等?
a==b || a==c || b==c 输出'Isosceles triangle' 跳过 是否三边相等?
a==b==c 输出'Equilateral triangle' 跳过 a² + b² == c²? 计算平方和
a² + b² vs c² 输出'Right triangle' a² + b² > c²? 输出'Acute triangle' 输出'Obtuse triangle' 开始 主函数调用 读取输入数据
sides = list(map(int, input().split())) 排序三边
sides.sort() 解包变量
a,b,c = sides[0],sides[1],sides[2] 是否构成三角形?
a+b > c ? 输出'Not triangle' 结束

相关推荐
white-persist10 分钟前
CSRF 漏洞全解析:从原理到实战
网络·python·安全·web安全·网络安全·系统安全·csrf
以己之21 分钟前
NC313 两个数组的交集
算法·哈希算法
William_cl26 分钟前
【C# OOP 入门到精通】从基础概念到 MVC 实战(含 SOLID 原则与完整代码)
开发语言·c#·mvc
Brookty28 分钟前
【算法】前缀和
java·学习·算法·前缀和·动态规划
Bellafu66642 分钟前
本地搭建EXAM-MASTER考试系统
python
开心-开心急了1 小时前
Flask入门教程——李辉 第三章 关键知识梳理
后端·python·flask
And_Ii1 小时前
LeetCode 3397. 执行操作后不同元素的最大数量
数据结构·算法·leetcode
额呃呃1 小时前
leetCode第33题
数据结构·算法·leetcode
隐语SecretFlow1 小时前
【隐语SecretFlow用户案例】亚信科技构建统一隐私计算框架探索实践
科技·算法·安全·隐私计算·隐私求交·开源隐私计算
dragoooon341 小时前
[优选算法专题四.前缀和——NO.27 寻找数组的中心下标]
数据结构·算法·leetcode