0114 - FNumarDivizoriImpari: Difference between revisions

From Bitnami MediaWiki
 
(2 intermediate revisions by the same user not shown)
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("Numarul introdus nu este valid.")
         print("Datele de intrare nu corespund restricțiilor impuse")
     else:
     else:
         print("Datele de intrare sunt corecte.")
         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>


==Explicatii==
==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]

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]

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]

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]

  • 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]

Exemplul 1[edit]

Intrare
10
Ieșire
Datele de intrare corespund restricțiilor impuse.
2

Exemplul 2[edit]

Intrare
35
Ieșire
Datele de intrare corespund restricțiilor impuse.
4

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 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]

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.