Jump to content
Main menu
Main menu
move to sidebar
hide
Navigation
Main page
Recent changes
Random page
Help about MediaWiki
Bitnami MediaWiki
Search
Search
Create account
Log in
Personal tools
Create account
Log in
Pages for logged out editors
learn more
Contributions
Talk
Editing
0798 - Interval Factorial
Page
Discussion
English
Read
Edit
Edit source
View history
Tools
Tools
move to sidebar
hide
Actions
Read
Edit
Edit source
View history
General
What links here
Related changes
Special pages
Page information
Warning:
You are not logged in. Your IP address will be publicly visible if you make any edits. If you
log in
or
create an account
, your edits will be attributed to your username, along with other benefits.
Anti-spam check. Do
not
fill this in!
==Enunț== 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== 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== 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== 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== 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== ;Intrare :3 ;Ieșire :[3, 23] ==Important== 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== ===Rezolvare ver. 1=== <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== 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.
Summary:
Please note that all contributions to Bitnami MediaWiki may be edited, altered, or removed by other contributors. If you do not want your writing to be edited mercilessly, then do not submit it here.
You are also promising us that you wrote this yourself, or copied it from a public domain or similar free resource (see
Bitnami MediaWiki:Copyrights
for details).
Do not submit copyrighted work without permission!
Cancel
Editing help
(opens in new window)
Toggle limited content width