0030 - AfisareMultipli: Difference between revisions

From Bitnami MediaWiki
 
(2 intermediate revisions by the same user not shown)
Line 9: Line 9:
==Date de ieșire==
==Date de ieșire==


*afișarea pe ecran a primelor n numere naturale nenule divizibile cu k, în ordine descrescătoare, separate prin câte un spațiu
Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." și programul va afișa primele n numere naturale nenule divizibile cu k, în ordine descrescătoare, separate prin câte un spațiu. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse.".


==Restricții de precizări==
==Restricții de precizări==
Line 21: Line 21:
==Exemplu==
==Exemplu==


Dacă n = 3 și k = 5, apelul subprogramului va afișa pe ecran:
;Intrare
'''15 10 5'''
:3
:5
;Ieșire
:Datele de intrare sunt corecte.
:15,10,5


==Important==
==Important==
Line 41: Line 45:
         return False
         return False
     return True
     return True


# Definim funcția sub care primește doi parametri n și k
# Definim funcția sub care primește doi parametri n și k
Line 47: Line 52:
     i = k * n
     i = k * n
     while n > 0:
     while n > 0:
         print(i, end=' ')
         if n > 1:
            print(i, end=',')
        else:
            print(i)
         i -= k
         i -= k
         n -= 1
         n -= 1


# Program principal
# Program principal
Line 56: Line 65:
     n = int(input("Introduceți numărul de elemente: "))
     n = int(input("Introduceți numărul de elemente: "))
     k = int(input("Introduceți divizorul: "))
     k = int(input("Introduceți divizorul: "))
   
 
     # Verificăm restricțiile impuse în cerință
     # Verificăm restricțiile impuse în cerință
     if n <= 0 or n > 50:
     if n <= 0 or n > 50:
Line 65: Line 74:
         # Apelăm funcția sub și afișăm rezultatul
         # Apelăm funcția sub și afișăm rezultatul
         print("Datele de intrare sunt corecte.")
         print("Datele de intrare sunt corecte.")
         sub(n, k)  
         sub(n, k)


</syntaxhighlight>
</syntaxhighlight>

Latest revision as of 16:40, 6 May 2023

Cerință[edit]

Scrieți definiția completă a funcției Python sub care primește doi parametri n și k și determină afișarea pe ecran, în ordine descrescătoare, a primelor n numere naturale nenule divizibile cu k.


Date de intrare[edit]

Se citește de la tastatură n (numărul de numere naturale nenule divizibile cu k ce urmează a fi afișate) și k (numărul cu care trebuie să fie divizibile numerele afișate).

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 primele n numere naturale nenule divizibile cu k, în ordine descrescătoare, separate prin câte un spațiu. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse.".

Restricții de precizări[edit]

  • numele funcției va fi sub
  • funcția va avea exact doi parametri, în ordinea: n, respectiv k
  • 0 < n ≤ 50, 0 < k ≤ 20
  • cele n numere vor fi afișate pe aceeași linie, separate prin câte un spațiu


Exemplu[edit]

Intrare
3
5
Ieșire
Datele de intrare sunt corecte.
15,10,5

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, k):

   if not isinstance(n, int) or n <= 0 or n > 50:
       print("Eroare: n trebuie să fie un număr întreg pozitiv între 1 și 50.")
       return False
   if not isinstance(k, int) or k <= 0 or k > 20:
       print("Eroare: k trebuie să fie un număr întreg pozitiv între 1 și 20.")
       return False
   return True


  1. Definim funcția sub care primește doi parametri n și k
  2. și afișează primele n numere divizibile cu k în ordine descrescătoare.

def sub(n, k):

   i = k * n
   while n > 0:
       if n > 1:
           print(i, end=',')
       else:
           print(i)
       i -= k
       n -= 1


  1. Program principal

if __name__ == '__main__':

   # Citim valorile n și k de la tastatură
   n = int(input("Introduceți numărul de elemente: "))
   k = int(input("Introduceți divizorul: "))
   # Verificăm restricțiile impuse în cerință
   if n <= 0 or n > 50:
       print("Eroare: n trebuie să fie între 1 și 50.")
   elif k <= 0 or k > 20:
       print("Eroare: k trebuie să fie între 1 și 20.")
   else:
       # Apelăm funcția sub și afișăm rezultatul
       print("Datele de intrare sunt corecte.")
       sub(n, k)

</syntaxhighlight>

Explicatii[edit]

Acest cod definește o funcție sub(n, k) care primește doi parametri, n și k, și afișează primele n numere divizibile cu k în ordine descrescătoare. Programul citește valorile n și k de la tastatură și verifică dacă acestea respectă restricțiile impuse în cerință, folosind funcția de validare validare(n, k).

Funcția validare(n, k) verifică dacă n și k sunt numere întregi pozitive și dacă se încadrează în intervalele impuse în cerință. Dacă valorile nu respectă aceste restricții, se afișează un mesaj de eroare corespunzător și se returnează False. În caz contrar, se returnează True.

Dacă ambele valori de intrare sunt valide, programul afișează mesajul "Datele de intrare sunt corecte." și apelează funcția sub(n, k), care calculează primele n numere divizibile cu k în ordine descrescătoare și le afișează pe ecran, separate prin câte un spațiu.

Notă: Acest cod nu utilizează funcția de validare validare(n, k). Pentru a utiliza această funcție, trebuie să înlocuiți blocul de cod care verifică restricțiile impuse în cerință cu apelul funcției validare.