3813 - Unghiuri

De la Universitas MediaWiki

Cerință

Se dau lungimile laturilor unui triunghi ABC. Aflati masurile unghiurilor A, B, C.


Date de intrare

Programul citește de la tastatură lungimile laturilor AB, BC, AC.


Date de ieșire

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." Programul va afișa pe ecran masura unghiurilor A, B, C cu 2 zecimale exacte daca triunghiul este valid, altfel se afiseaza mesajul Imposibil. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse."

Restricții și precizări

  • 1 ≤ AB,BC,AC ≤ 1000

Exemplul 1

Intrare
7 8 6


Ieșire
Datele de intrare corespund restrictiilor impuse.
57.91 75.52 46.57

Exemplul 2

Intrare
4 5 10


Ieșire
Datele de intrare corespund restrictiilor impuse.
Imposibil

Rezolvare

Rezolvare ver. 1

import math


def validate_triangle(a, b, c):
    """
    Verifica daca triunghiul cu laturile a, b si c este valid.
    Returneaza True daca triunghiul este valid, altfel False.
    """
    if int(a) + int(b) <= int(c) or int(a) + int(c) <= int(b) or int(b) + int(c) <= int(a):
        return False
    return True


def validare2(a, b, c):
    return 1 <= int(a) <= 1000 and 1 <= int(b) <= 1000 and 1 <= int(c) <= 1000


def calculate_angles(a, b, c):
    """
    Calculeaza masurile unghiurilor triunghiului cu laturile a, b si c.
    Returneaza un tuple cu valorile ungiurilor in ordinea A, B, C.
    """
    if not validate_triangle(a, b, c):
        return "Imposibil"

    angle_a = round(math.degrees(math.acos((b ** 2 + c ** 2 - a ** 2) / (2 * b * c))), 2)
    angle_b = round(math.degrees(math.acos((a ** 2 + c ** 2 - b ** 2) / (2 * a * c))), 2)
    angle_c = round(math.degrees(math.acos((a ** 2 + b ** 2 - c ** 2) / (2 * a * b))), 2)

    return (angle_a, angle_b, angle_c)


if __name__ == "__main__":
    a, b, c = map(str, input().split())
    if validare2(a, b, c):
        a, b, c = float(a), float(b), float(c)
        print("Datele de intrare corespund restrictiilor impuse.")
        angles = calculate_angles(a, b, c)
        if angles == "Imposibil":
            print("Imposibil")
        else:
            print(*angles)
    else:
        print("Datele de intrare nu corespund restrictiilor impuse.")

Explicație

Acest program calculează măsurile unghiurilor unui triunghi dat de lungimile laturilor sale.

Funcția validate_triangle(a, b, c) primește ca parametrii lungimile laturilor unui triunghi și verifică dacă triunghiul respectiv este valid, adică îndeplinește condițiile de existență ale unui triunghi: fiecare latură trebuie să fie mai mică decât suma celorlalte două laturi. Dacă triunghiul este valid, funcția returnează True, în caz contrar returnează False.

Funcția validare2(a, b, c) verifică dacă laturile triunghiului se încadrează în limitele impuse, în caz afirmativ returnează True, în caz contrar returnează False.

Funcția calculate_angles(a, b, c) primește ca parametrii lungimile laturilor triunghiului și calculează măsurile unghiurilor acestuia folosind formula lui Cosinus. Dacă triunghiul nu este valid, funcția returnează "Imposibil", altfel returnează un tuplu cu măsurile unghiurilor în ordinea A, B, C.

În funcția principală (if __name__ == "__main__":) se citesc lungimile laturilor triunghiului sub forma unor string-uri, se verifică dacă acestea respectă limitele impuse, apoi se convertesc în float-uri și se calculează măsurile unghiurilor triunghiului. Dacă triunghiul nu este valid, se afișează "Imposibil", altfel se afișează măsurile unghiurilor.