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

相关推荐
我带你来这儿就是为了告诉你我几秒前
C++23新特性前瞻
开发语言·c++·算法
陌夏4 分钟前
快速排序 (Quick Sort)
算法
IronMurphy14 分钟前
【算法二十九】 437. 路径总和 III
算法·深度优先
jinanwuhuaguo15 分钟前
OpenClaw安全使用实践全景深度指南:从“裸奔龙虾”到“可信数字堡垒”的体系化构建
开发语言·php
2501_9083298515 分钟前
C++安全编程指南
开发语言·c++·算法
计算机安禾17 分钟前
【C语言程序设计】第39篇:预处理器与宏定义
c语言·开发语言·c++·vscode·算法·visual studio code·visual studio
巧妹儿18 分钟前
Python 配置管理封神技:pydantic_settings+@lru_cache,支持优先级,安全又高效,杜绝重复加载!
开发语言·python·ai·配置管理
独隅22 分钟前
Python AI 全面使用指南:从数据基石到智能决策
开发语言·人工智能·python
胡耀超26 分钟前
Web Crawling 网络爬虫全景:技术体系、反爬对抗与全链路成本分析
前端·爬虫·python·网络爬虫·数据采集·逆向工程·反爬虫
m0_5698814728 分钟前
C++中的装饰器模式变体
开发语言·c++·算法