0798 - Interval Factorial: Difference between revisions

From Bitnami MediaWiki
 
(3 intermediate revisions by the same user not shown)
Line 11: Line 11:


==Date de intrare==
==Date de intrare==
*un număr natural '''n''', reprezentând numărul pentru care se caută intervalul factorial
Se citește de la tastatură un număr natural '''n''', reprezentând numărul pentru care se caută intervalul factorial.
 
 
==Date de ieșire==
==Date de ieșire==
*două numere naturale '''a''' și '''b''', care reprezintă capetele intervalului factorial al lui n de lungime maximă
Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." și programul va afișa două numere naturale '''a''' și '''b''', care reprezintă capetele intervalului factorial al lui n de lungime maximă. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse.".


==Restricţii şi precizări==
==Restricţii şi precizări==
Line 25: Line 25:


==Exemplu==
==Exemplu==
 
;Intrare
Dacă '''n=3''', apelul subprogramului va furniza prin parametrul '''a''' valoarea '''3''', iar prin '''b''' valoarea '''23'''.
:3
 
;Ieșire
:[3, 23]


==Important==
==Important==
Line 72: Line 73:




==Explicatii==
==Explicații==
In acest cod, functia validare verifica daca numarul n primit ca parametru este in intervalul [2,10]. Daca numarul este in afara acestui interval, se afiseaza un mesaj de eroare si se returneaza False. Daca numarul este in interval, se returneaza True.
In acest cod, functia validare verifica daca numarul n primit ca parametru este in intervalul [2,10]. Daca numarul este in afara acestui interval, se afiseaza un mesaj de eroare si se returneaza False. Daca numarul este in interval, se returneaza True.



Latest revision as of 17:19, 6 May 2023

Enunț[edit]

Un interval cu proprietatea că există un singur număr natural, n (2≤n), pentru care valoarea produsului 1·2·3·...·n aparține acestui interval este numit interval factorial al lui n. Exemplu: [5,8] și [3,23] sunt intervale factoriale ale lui 3, dar [1,15] și [7,10] nu sunt intervale factoriale ale niciunui număr.

Cerinţa[edit]

Să se scrie o funcție Python care, pentru un număr natural n transmis ca parametru, determină și întoarce prin intermediul unor parametrii de ieșire un interval factorial al lui n de lungime maximă.


Date de intrare[edit]

Se citește de la tastatură un număr natural n, reprezentând numărul pentru care se caută intervalul factorial.

Date de ieșire[edit]

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." și programul va afișa două numere naturale a și b, care reprezintă capetele intervalului factorial al lui n de lungime maximă. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse.".

Restricţii şi precizări[edit]

Numele funcției va fi interval și va avea exact trei parametri, în această ordine:

  • primul parametru, n, reprezintă un număr natural din intervalul [2,10]
  • a și b, prin care furnizează câte un număr natural, astfel încât expresia b-a să aibă valoare maximă, iar [a,b] să fie interval factorial al lui n.


Exemplu[edit]

Intrare
3
Ieșire
[3, 23]

Important[edit]

Soluţia propusă va conţine doar definiţia funcţiei cerute. Prezenţa în soluţie a altor instrucţiuni poate duce erori de compilare sau de execuţie care vor avea ca efect depunctarea soluţiei.

Rezolvare[edit]

Rezolvare ver. 1[edit]

<syntaxhighlight lang="python" line="1" start="1">

def validare(n):

   if n < 2 or n > 10:
       print("Numarul introdus trebuie sa fie intre 2 si 10.")
       return False
   return True

def interval(n):

   produs = 1
   i = 1
   while produs <= n:
       produs *= i
       i += 1
   a = 2
   while produs > n:
       produs //= a
       a += 1
   b = a - 1
   while produs <= i:
       produs *= b + 1
       b += 1
   return a, b

def main():

   n = int(input("Introduceti numarul n: "))
   if validare(n):
       a, b = interval(n)
       print(f"Intervalul factorial al lui {n} este [{a}, {b}].")

if __name__ == "__main__":

   main()


</syntaxhighlight>


Explicații[edit]

In acest cod, functia validare verifica daca numarul n primit ca parametru este in intervalul [2,10]. Daca numarul este in afara acestui interval, se afiseaza un mesaj de eroare si se returneaza False. Daca numarul este in interval, se returneaza True.

Functia interval determina intervalul factorial al lui n de lungime maxima. Pentru aceasta, se calculeaza produsul primelor i numere naturale pana cand produsul depaseste n. De aici, se calculeaza capatul inferior a al intervalului factorial, prin impartirea succesiva a produsului la numerele naturale de la 2 la a-1, pana cand produsul devine mai mic sau egal cu i. Apoi, se calculeaza capatul superior b al intervalului factorial, prin inmultirea succesiva a produsului cu numerele naturale de la b+1 la i-1, pana cand produsul devine mai mare sau egal cu i.

In functia main, se citeste numarul n de la tastatura si se verifica daca este un numar valid prin apelarea functiei validare. Daca numarul este valid, se determina intervalul factorial al lui n prin apelarea functiei interval si se afiseaza intervalul respectiv.

La final, daca acest cod este rulat ca program principal (__name__ == "__main__"), functia main este apelata pentru a rula intregul program.