0018 - Numarul de Divizori: Difference between revisions

From Bitnami MediaWiki
No edit summary
Line 1: Line 1:
== Enunț ==
Se dă un număr natural '''n'''.
== Cerinţa ==
== Cerinţa ==
Se dă un număr natural numit ”'''numar'''”. Calculaţi numărul de divizori ai acestui numar.
Calculaţi numărul de divizori ai lui '''n'''.  
== Date de intrare ==
== Date de intrare ==
Fişierul de intrare '''nrdiv.in''' conţine pe prima linie numărul '''numar'''
Fişierul de intrare '''nrdiv.in''' conţine pe prima linie numărul '''n'''
== Date de ieşire ==
== Date de ieşire ==
Fişierul de ieşire '''nrdiv.out''' va conţine pe prima linie numărul '''numar_divizori''', reprezentând numărul de divizori ai lui '''numar'''.
Fişierul de ieşire '''nrdiv.out''' va conţine pe prima linie numărul '''rez''', reprezentând numărul de divizori ai lui '''n'''.
Dacă datele sunt introduse corect, în fișier se va afișa:'''"Datele sunt introduse corect."''', apoi pe un rând nou fişierul de ieşire '''nrdiv.out''' va conţine numărul '''rez''', reprezentând numărul de divizori ai lui '''n'''. În cazul în care datele nu respectă restricțiile, se va afișa în fișier:'''"Datele nu corespund restricțiilor impuse."'''.
== Restricții și precizări ==
== Restricții și precizări ==
* numar ∈ Ν
* n ∈ Ν
* 0 ⩽ numar ⩽ 100.000
* 0 ⩽ n ⩽ 100.000
== Exemplu ==
== Exemplu ==
; Intrare
; Intrare
: 6
: 6
; Ieșire
; Ieșire
: Datele introduse corespund restricțiilor impuse.
: Datele sunt introduse corect.
: 4
: 4
== Explicație ==  
== Explicație ==  
Line 18: Line 21:
== Rezolvare ==
== Rezolvare ==
<syntaxhighlight lang="python" line>
<syntaxhighlight lang="python" line>
def validare_date(numar):
# Funcție care verifica restricțiile date
def validare_date(n):
     flag = False
     flag = False
     if numar.isdigit():
     if isinstance(n, int):
         if 0 <= int(numar) <= 1_000_000_000:
         if 0 <= n <= 1_000_000_000:
             flag = True
             flag = True
     return flag
     return flag


 
#Funcție care calculează numărul de divizori ai unui număr întreg n.
def nr_divizori(n):
def nr_divizori(n):
     numar_divizori = 0
     numar_divizori = 0
Line 35: Line 39:


if __name__ == '__main__':
if __name__ == '__main__':
     numar = input()
     with open('nrdiv.in', 'r') as f_in:
    if validare_date(numar):
        n = int(f_in.readline())
        print("\nDatele de intrare corespund restricțiilor impuse.\n")
    # Dacă numarul n nu este valid, afișăm un mesaj corespunzător în fișierul de ieșire nrdiv.out si ieșim din program cu exit().
        with open('nrdiv.in', 'r') as f:
    if not validare_date(n):
            n = int(f.readline())
         with open('nrdiv.out', 'w') as f_out:
         with open('nrdiv.out', 'w') as f:
             f_out.write("\nDatele nu corespund restricțiilor impuse.\n")
             f.write(str(nr_divizori(n)))
            exit()
    # În caz afirmativ calculăm și afișăm numărul de divizori ai lui n în același fișier de ieșire.
     else:
     else:
         print("Datele de intrare nu corespund restricțiilor impuse.")
         with open('nrdiv.out', 'w') as f_out:
            f_out.write("Datele sunt introduse corect.\n")
            f_out.write(str(nr_divizori(n)))




</syntaxhighlight>
</syntaxhighlight>

Revision as of 17:57, 11 April 2023

Enunț

Se dă un număr natural n.

Cerinţa

Calculaţi numărul de divizori ai lui n.

Date de intrare

Fişierul de intrare nrdiv.in conţine pe prima linie numărul n

Date de ieşire

Fişierul de ieşire nrdiv.out va conţine pe prima linie numărul rez, reprezentând numărul de divizori ai lui n. Dacă datele sunt introduse corect, în fișier se va afișa:"Datele sunt introduse corect.", apoi pe un rând nou fişierul de ieşire nrdiv.out va conţine numărul rez, reprezentând numărul de divizori ai lui n. În cazul în care datele nu respectă restricțiile, se va afișa în fișier:"Datele nu corespund restricțiilor impuse.".

Restricții și precizări

  • n ∈ Ν
  • 0 ⩽ n ⩽ 100.000

Exemplu

Intrare
6
Ieșire
Datele sunt introduse corect.
4

Explicație

Pentru numărul 6 avem divizorii 1, 2, 3, 6 deci numărul acestora este egal cu 4.

Rezolvare

<syntaxhighlight lang="python" line>

  1. Funcție care verifica restricțiile date

def validare_date(n):

   flag = False
   if isinstance(n, int):
       if 0 <= n <= 1_000_000_000:
           flag = True
   return flag
  1. Funcție care calculează numărul de divizori ai unui număr întreg n.

def nr_divizori(n):

   numar_divizori = 0
   for i in range(1, n + 1):
       if n % i == 0:
           numar_divizori += 1
   return numar_divizori


if __name__ == '__main__':

   with open('nrdiv.in', 'r') as f_in:
       n = int(f_in.readline())
   # Dacă numarul n nu este valid, afișăm un mesaj corespunzător în fișierul de ieșire nrdiv.out si ieșim din program cu exit().
   if not validare_date(n):
       with open('nrdiv.out', 'w') as f_out:
           f_out.write("\nDatele nu corespund restricțiilor impuse.\n")
           exit()
   # În caz afirmativ calculăm și afișăm numărul de divizori ai lui n în același fișier de ieșire.
   else:
       with open('nrdiv.out', 'w') as f_out:
           f_out.write("Datele sunt introduse corect.\n")
           f_out.write(str(nr_divizori(n)))


</syntaxhighlight>