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

相关推荐
不知天地为何吴女士1 小时前
Day32| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法
小坏坏的大世界1 小时前
C++ STL常用容器总结(vector, deque, list, map, set)
c++·算法
wjs20242 小时前
状态模式(State Pattern)
开发语言
我命由我123452 小时前
Kotlin 数据容器 - List(List 概述、创建 List、List 核心特性、List 元素访问、List 遍历)
java·开发语言·jvm·windows·java-ee·kotlin·list
liulilittle2 小时前
C++ TAP(基于任务的异步编程模式)
服务器·开发语言·网络·c++·分布式·任务·tap
im_AMBER3 小时前
学习日志19 python
python·学习
励志要当大牛的小白菜4 小时前
ART配对软件使用
开发语言·c++·qt·算法
qq_513970444 小时前
力扣 hot100 Day56
算法·leetcode
PAK向日葵5 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
mortimer6 小时前
安装NVIDIA Parakeet时,我遇到的两个Pip“小插曲”
python·github