2670 - Ecuatie 4: Difference between revisions

From Bitnami MediaWiki
Pagină nouă: == Cerinţa == Se da un poligon regulat cu '''n''' laturi si '''a''' lungimea unei laturi. Aflati distanta de la centrul poligonului la oricare varf. == Date de intrare == Programul citește de la tastatură numerele '''n''' si '''a'''. == Date de ieşire == Programul va afișa pe ecran numărul '''r''', reprezentand distanta de la centrul poligonului la varf, cu '''2''' zecimale exacte, fără rotunjire. == Restricții și precizări == * 3 ⩽ n ⩽ 360 * 1 ⩽ a &les...
 
No edit summary
 
(3 intermediate revisions by the same user not shown)
Line 12: Line 12:
: 3 2
: 3 2
; Ieșire
; Ieșire
: Datele introduse corespund restricțiilor impuse.
: 1.15
: 1.15
== Exemplul 2 ==
== Exemplul 2 ==
Line 17: Line 18:
: 4 2
: 4 2
; Ieșire
; Ieșire
: Datele introduse corespund restricțiilor impuse.
: 1.41
: 1.41
== Exemplul 3 ==
== Exemplul 3 ==
Line 22: Line 24:
: 6 3
: 6 3
; Ieșire
; Ieșire
: 3.00  
: Datele introduse corespund restricțiilor impuse.
: 3.00
== Exemplul 4 ==
; Intrare
: 3 n
; Ieșire
: Datele de intrare nu corespund restricțiilor impuse.
 
== Rezolvare ==
== Rezolvare ==
<syntaxhighlight lang="python" line>
<syntaxhighlight lang="python" line>
# 2670 - Ecuatie 4
import math
import math


def calculeaza_distanta(n, a):
    # Calcularea distanței de la centrul poligonului la oricare vârf
    r = (a / 2) / math.sin(math.pi / n)
    return r


if __name__ == "__main__":
def validare(n1, a1):              # functia de validare a datelor de intrare
     # Citirea datelor de intrare
    if not (3 <= n1 <= 360 and 1 <= a1 <= 1000):
     n = int(input("Introduceți numărul de laturi ale poligonului: "))
        raise ValueError
     a = float(input("Introduceți lungimea unei laturi: "))
    print("Datele introduse corespund restricțiilor impuse.")
     return True
 
 
def distanta(n1, a1):            # functia de rezolvare
     r1 = a1 / (2 * math.sin(math.pi / n1))  # formula pentru distanta de la centrul poligonului la varf
     return round(r1, 2)
 


     # Apelarea funcției pentru calcularea distanței
if __name__ == '__main__':
     r = calculeaza_distanta(n, a)
     # din cauza datelor de intrare pot aparea 2 tipuri de erori, valueError sau IndexError pe care le tratam
     try:
        n = int(input("Introduceti numarul de laturi n: "))          # citirea numarului de laturi
        a = int(input("Introduceti lungimea unei laturi a: "))      # citirea lungimii unei laturi
        validare(n, a)                              # apelul functiei de validare
        r = distanta(n, a)                          # apelul functiei de rezolvare
        print(f" {r}")


     # Afișarea rezultatului cu două zecimale exacte
     except ValueError:
     print("{:.2f}".format(r))
        print("Datele de intrare nu corespund restricțiilor impuse.")
     except IndexError:
        print("Datele de intrare nu corespund restricțiilor impuse.")


</syntaxhighlight>
</syntaxhighlight>

Latest revision as of 21:56, 14 November 2023

Cerinţa[edit | edit source]

Se da un poligon regulat cu n laturi si a lungimea unei laturi. Aflati distanta de la centrul poligonului la oricare varf.

Date de intrare[edit | edit source]

Programul citește de la tastatură numerele n si a.

Date de ieşire[edit | edit source]

Programul va afișa pe ecran numărul r, reprezentand distanta de la centrul poligonului la varf, cu 2 zecimale exacte, fără rotunjire.

Restricții și precizări[edit | edit source]

  • 3 ⩽ n ⩽ 360
  • 1 ⩽ a ⩽ 1000

Exemplul 1[edit | edit source]

Intrare
3 2
Ieșire
Datele introduse corespund restricțiilor impuse.
1.15

Exemplul 2[edit | edit source]

Intrare
4 2
Ieșire
Datele introduse corespund restricțiilor impuse.
1.41

Exemplul 3[edit | edit source]

Intrare
6 3
Ieșire
Datele introduse corespund restricțiilor impuse.
3.00

Exemplul 4[edit | edit source]

Intrare
3 n
Ieșire
Datele de intrare nu corespund restricțiilor impuse.

Rezolvare[edit | edit source]

<syntaxhighlight lang="python" line>

  1. 2670 - Ecuatie 4

import math


def validare(n1, a1): # functia de validare a datelor de intrare

   if not (3 <= n1 <= 360 and 1 <= a1 <= 1000):
       raise ValueError
   print("Datele introduse corespund restricțiilor impuse.")
   return True


def distanta(n1, a1): # functia de rezolvare

   r1 = a1 / (2 * math.sin(math.pi / n1))  # formula pentru distanta de la centrul poligonului la varf
   return round(r1, 2)


if __name__ == '__main__':

   # din cauza datelor de intrare pot aparea 2 tipuri de erori, valueError sau IndexError pe care le tratam
   try:
       n = int(input("Introduceti numarul de laturi n: "))          # citirea numarului de laturi
       a = int(input("Introduceti lungimea unei laturi a: "))       # citirea lungimii unei laturi
       validare(n, a)                               # apelul functiei de validare
       r = distanta(n, a)                          # apelul functiei de rezolvare
       print(f" {r}")
   except ValueError:
       print("Datele de intrare nu corespund restricțiilor impuse.")
   except IndexError:
       print("Datele de intrare nu corespund restricțiilor impuse.")

</syntaxhighlight>