0114 - FNumarDivizoriImpari: Difference between revisions
Cuceu Andrei (talk | contribs) No edit summary |
Vardai Erwin (talk | contribs) |
||
(4 intermediate revisions by the same user not shown) | |||
Line 5: | Line 5: | ||
==Date de intrare== | ==Date de intrare== | ||
Se citește un număr natural de la tastatură, mai mare decât '''1''' și mai mic decât '''2.000.000.000 | |||
==Date de ieșire== | ==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 un număr natural reprezentând numărul de divizori impari ai numărului dat ca parametru. Î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 16: | Line 16: | ||
*numărul pentru care se calculează numărul divizorilor impari va fi mai mare decât 1 și mai mic decât '''2.000.000.000''' | *numărul pentru care se calculează numărul divizorilor impari va fi mai mare decât 1 și mai mic decât '''2.000.000.000''' | ||
==Exemplu== | |||
===Exemplul 1=== | |||
;Intrare | |||
:10 | |||
;Ieșire | |||
:Datele de intrare corespund restricțiilor impuse. | |||
:2 | |||
===Exemplul 2=== | |||
;Intrare | |||
:35 | |||
;Ieșire | |||
:Datele de intrare corespund restricțiilor impuse. | |||
:4 | |||
==Important== | ==Important== | ||
Line 24: | Line 39: | ||
===Rezolvare ver. 1=== | ===Rezolvare ver. 1=== | ||
<syntaxhighlight lang="python" line="1" start="1"> | <syntaxhighlight lang="python" line="1" start="1"> | ||
def validate_input(n): | def validate_input(n): | ||
if n <= 1 or n >= 2000000000: | if n <= 1 or n >= 2000000000: | ||
return False | return False | ||
return True | return True | ||
def nr_div_imp(n): | def nr_div_imp(n): | ||
Line 34: | Line 49: | ||
return -1 | return -1 | ||
result = 0 | result = 0 | ||
for i in range(1, n+1, 2): | for i in range(1, n + 1, 2): | ||
if n % i == 0: | if n % i == 0: | ||
result += 1 | result += 1 | ||
return result | return result | ||
if __name__ == '__main__': | if __name__ == '__main__': | ||
Line 43: | Line 59: | ||
result = nr_div_imp(n) | result = nr_div_imp(n) | ||
if result == -1: | if result == -1: | ||
print(" | print("Datele de intrare nu corespund restricțiilor impuse") | ||
else: | else: | ||
print("Datele de intrare | print("Datele de intrare corespund restricțiilor impuse.") | ||
print("Numarul de divizori impari ai lui", n, "este:", result) | print("Numarul de divizori impari ai lui", n, "este:", result) | ||
</syntaxhighlight> | </syntaxhighlight> | ||
== | ==Explicații== | ||
Acest cod conține două funcții: nr_div_imp(n) și validate_input(n), împreună cu o funcție principală main. | Acest cod conține două funcții: nr_div_imp(n) și validate_input(n), împreună cu o funcție principală main. | ||
Latest revision as of 17:15, 6 May 2023
Cerinţa[edit | edit source]
Să se scrie o funcție Python care să determine numărul divizorilor impari ai unui număr natural transmis ca parametru. Funcția întoarce rezultatul prin intermediul unui parametru de ieşire.
Date de intrare[edit | edit source]
Se citește un număr natural de la tastatură, mai mare decât 1 și mai mic decât 2.000.000.000
Date de ieșire[edit | edit source]
Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." și programul va afișa un număr natural reprezentând numărul de divizori impari ai numărului dat ca parametru. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse.".
Restricţii şi precizări[edit | edit source]
- numele funcției va fi nr_div_imp
- funcția va avea doi parametri, reprezentând numărul pentru care se calculează numarul divizorilor *impari, respectiv valoarea calculată
- numărul pentru care se calculează numărul divizorilor impari va fi mai mare decât 1 și mai mic decât 2.000.000.000
Exemplu[edit | edit source]
Exemplul 1[edit | edit source]
- Intrare
- 10
- Ieșire
- Datele de intrare corespund restricțiilor impuse.
- 2
Exemplul 2[edit | edit source]
- Intrare
- 35
- Ieșire
- Datele de intrare corespund restricțiilor impuse.
- 4
Important[edit | edit source]
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 | edit source]
Rezolvare ver. 1[edit | edit source]
<syntaxhighlight lang="python" line="1" start="1"> def validate_input(n):
if n <= 1 or n >= 2000000000: return False return True
def nr_div_imp(n):
if not validate_input(n): return -1 result = 0 for i in range(1, n + 1, 2): if n % i == 0: result += 1 return result
if __name__ == '__main__':
n = int(input("Introduceti numarul n: ")) result = nr_div_imp(n) if result == -1: print("Datele de intrare nu corespund restricțiilor impuse") else: print("Datele de intrare corespund restricțiilor impuse.") print("Numarul de divizori impari ai lui", n, "este:", result)
</syntaxhighlight>
Explicații[edit | edit source]
Acest cod conține două funcții: nr_div_imp(n) și validate_input(n), împreună cu o funcție principală main.
Funcția nr_div_imp(n) primește un număr natural n ca parametru și calculează numărul de divizori impari ai lui n. Pentru aceasta, folosește un ciclu for care parcurge toate numerele impare de la 1 până la n. Pentru fiecare număr impar verifică dacă este divizor al lui n și, în caz afirmativ, adaugă 1 la variabila result. La sfârșit, funcția returnează valoarea variabilei result.
Funcția validate_input(n) primește, de asemenea, un număr natural n ca parametru și verifică dacă acesta este un număr valid, adică mai mare decât 1 și mai mic decât 2.000.000.000. Dacă numărul este valid, funcția returnează True, în caz contrar, returnează False.
Funcția principală main primește un număr natural n de la utilizator, apoi apelează funcția nr_div_imp(n) pentru a calcula numărul de divizori impari ai lui n. Dacă numărul introdus nu este valid, afișează un mesaj corespunzător. În caz contrar, afișează un mesaj care confirmă corectitudinea datelor de intrare și afișează numărul de divizori impari ai lui n.