1847 - VectorSumPrim REC: Difference between revisions

From Bitnami MediaWiki
No edit summary
No edit summary
 
(One intermediate revision by the same user not shown)
Line 1: Line 1:
==Cerinţa==
==Cerinţa==
Scrieți definiția completă a subprogramului recursiv P care primeşte prin intermediul parametrului <code>n</code> un număr natural nenul (n≤100), iar prin intermediul parametrului <code>x</code> un tablou unidimensional cu <code>n</code> componente întregi, de maximum șase cifre fiecare.
Scrieți definiția completă a subprogramului recursiv P care primeşte prin intermediul parametrului n un număr natural nenul (n≤100), iar prin intermediul parametrului x un tablou unidimensional cu n componente întregi, de maximum șase cifre fiecare.
Subprogramul furnizează prin intermediul parametrului s suma elementelor din tabloul <code>x</code> care au valori numere prime.
Subprogramul furnizează prin intermediul parametrului s suma elementelor din tabloul x care au valori numere prime.


==Date de intrare==
==Date de intrare==
Line 7: Line 7:


==Date de ieșire==
==Date de ieșire==
Pe ecran se va afișa mesajul: "Datele de intrare corespund restricțiilor impuse."
Dacă datele de intrare corespund restrictiilor impuse se va afișa mesajul "Datele de intrare corespund restricțiilor" și pe un rând nou se afișează ceea ce se cere. Altfel, dacă datele de intrare nu corespund cerinței se va afișa mesajul: "Datele de intrare nu corespund cerinței".
În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul "Datele de intrare nu corespund restricțiilor impuse.".


==Restricţii şi precizări==
==Restricţii şi precizări==
0 < n ≤ 100
*0 < n ≤ 100
numele subprogramului cerut este P
*numele subprogramului cerut este P
parametrii sunt, în această ordine: x, n, s
*parametrii sunt, în această ordine: x, n, s
elementele vectorului x sunt indexate de la zero
*elementele vectorului x sunt indexate de la zero
se recomandă realizarea unei soluții recursive
*se recomandă realizarea unei soluții recursive


==Exemplu==
==Exemplu==
Dacă n=6 și x=(12, 7, 6, 3, 8, 5), după apel s=15.
===Exemplu 1===
:Intrare:
;Introduceți numărul de elemente din tablou: 6
;Introduceți elementul 1: 12
;Introduceți elementul 2: 7
;Introduceți elementul 3: 6
;Introduceți elementul 4: 3
;Introduceți elementul 5: 8
;Introduceți elementul 6: 5
:Iesire:
;Datele de intrare corespund restricțiilor impuse.
;Suma elementelor din tablou care sunt divizibile cu 3 este: 21
 
===Exemplu 2===
:Intrare:
;Introduceți numărul de elemente din tablou: 1234
:Iesire:
;Datele de intrare nu corespund restricțiilor impuse.


==Important==
==Important==
Line 24: Line 40:


==Rezolvare==
==Rezolvare==
#Funcția de validare:
<syntaxhighlight lang="python" line="1">
def validare_natural(n):
 
    Verifică dacă un număr este natural nenul (n > 0).
def validare_natural(n):
    Returnează True dacă este, False în caz contrar.
     return n > 0
     return n > 0
def validare_dimensiune_tablou(n):
 
    Verifică dacă un număr este mai mic sau egal cu 100 (dimensiunea maximă a tabloului).
def validare_dimensiune_tablou(n):
    Returnează True dacă este, False în caz contrar.
     return n <= 100
     return n <= 100
#Funcția de rezolvare:
 
def suma_divizibile_cu_3(v, n):
def suma_divizibile_cu_3(v, n):
     #Calculează suma elementelor dintr-un tablou unidimensional care sunt divizibile cu 3.
     return sum(x for x in v if x % 3 == 0)
    #Parametri:
 
    v: tabloul unidimensional (list)
def main():
    n: numărul efectiv de elemente din tablou (int)
    #Returnează suma elementelor din tabloul v care sunt divizibile cu 3 (int).
    if n == 0:
        return 0
    else:
        if v[n-1] % 3 == 0:
            return v[n-1] + suma_divizibile_cu_3(v, n-1)
        else:
            return suma_divizibile_cu_3(v, n-1)
#Funcția principală:
def main():
    #Funcția principală care citește datele de intrare și afișează rezultatul sau un mesaj de eroare.
     try:
     try:
         n = int(input("Introduceți numărul de elemente din tablou: "))
         n = int(input("Introduceți numărul de elemente din tablou: "))
         if not validare_natural(n) or not validare_dimensiune_tablou(n):
         if not validare_natural(n) or not validare_dimensiune_tablou(n):
             raise ValueError
             raise ValueError
         v = []
         v = [int(input(f"Introduceți elementul {i+1}: ")) for i in range(n)]
        for i in range(n):
            x = int(input(f"Introduceți elementul {i+1}: "))
            v.append(x)
         print("Datele de intrare corespund restricțiilor impuse.")
         print("Datele de intrare corespund restricțiilor impuse.")
         print(f"Suma elementelor din tablou care sunt divizibile cu 3 este: {suma_divizibile_cu_3(v, n)}")
         print(f"Suma elementelor din tablou care sunt divizibile cu 3 este: {suma_divizibile_cu_3(v, n)}")
     except ValueError:
     except ValueError:
         print("Datele de intrare nu corespund restricțiilor impuse.")
         print("Datele de intrare nu corespund restricțiilor impuse.")
#Funcția de validare:
 
def validare_natural(n):
if __name__ == "__main__":
    #Verifică dacă un număr este natural nenul (n > 0).
    main()
    #Returnează True dacă este, False în caz contrar.
</syntaxhighlight>
    return n > 0
 
def validare_dimensiune_tablou(n):
==Explicații==
    #Verifică dacă un număr este mai mic sau egal cu 100 (dimensiunea maximă a tabloului).
Codul scris este o implementare a cerințelor enunțate în problema de mai sus.
    #Returnează True dacă este, False în caz contrar.
 
    return n <= 100
Funcția validare_natural verifică dacă un număr este natural nenul (n > 0) și returnează True dacă este, False în caz contrar.
#Funcția de rezolvare:
 
def suma_prime(x, n, s=0, i=0):
Funcția validare_dimensiune_tablou verifică dacă un număr este mai mic sau egal cu 100 (dimensiunea maximă a tabloului) și returnează True dacă este, False în caz contrar.
    #Calculează suma elementelor prime dintr-un tablou unidimensional.
 
    #Parametri:
Funcția suma_divizibile_cu_3 calculează suma elementelor dintr-un tablou unidimensional care sunt divizibile cu 3 și primește ca parametri v - tabloul unidimensional și n - numărul efectiv de elemente din tablou.
    x: tabloul unidimensional (list)
 
    n: numărul de elemente din tablou (int)
Funcția main este funcția principală care citește datele de intrare și afișează rezultatul sau un mesaj de eroare. Ea folosește funcțiile de validare și de rezolvare pentru a verifica și procesa datele de intrare.
    s: suma elementelor prime din tabl
 
În cadrul funcției main, datele de intrare sunt citite de la tastatură și apoi sunt verificate utilizând funcțiile validare_natural și validare_dimensiune_tablou. Dacă datele de intrare sunt valide, se creează un tablou v care este umplut cu numerele citite de la tastatură și apoi se afișează mesajul "Datele de intrare corespund restricțiilor impuse" și suma elementelor din tablou care sunt divizibile cu 3, calculată utilizând funcția suma_divizibile_cu_3.
 
În caz contrar, dacă datele de intrare nu sunt valide, se afișează mesajul "Datele de intrare nu corespund restricțiilor impuse".

Latest revision as of 21:36, 14 May 2023

Cerinţa[edit | edit source]

Scrieți definiția completă a subprogramului recursiv P care primeşte prin intermediul parametrului n un număr natural nenul (n≤100), iar prin intermediul parametrului x un tablou unidimensional cu n componente întregi, de maximum șase cifre fiecare. Subprogramul furnizează prin intermediul parametrului s suma elementelor din tabloul x care au valori numere prime.

Date de intrare[edit | edit source]

Se va introduce de la tastatură un număr natural care va fi transmis ca perimetru

Date de ieșire[edit | edit source]

Dacă datele de intrare corespund restrictiilor impuse se va afișa mesajul "Datele de intrare corespund restricțiilor" și pe un rând nou se afișează ceea ce se cere. Altfel, dacă datele de intrare nu corespund cerinței se va afișa mesajul: "Datele de intrare nu corespund cerinței".

Restricţii şi precizări[edit | edit source]

  • 0 < n ≤ 100
  • numele subprogramului cerut este P
  • parametrii sunt, în această ordine: x, n, s
  • elementele vectorului x sunt indexate de la zero
  • se recomandă realizarea unei soluții recursive

Exemplu[edit | edit source]

Exemplu 1[edit | edit source]

Intrare:
Introduceți numărul de elemente din tablou
6
Introduceți elementul 1
12
Introduceți elementul 2
7
Introduceți elementul 3
6
Introduceți elementul 4
3
Introduceți elementul 5
8
Introduceți elementul 6
5
Iesire:
Datele de intrare corespund restricțiilor impuse.
Suma elementelor din tablou care sunt divizibile cu 3 este
21

Exemplu 2[edit | edit source]

Intrare:
Introduceți numărul de elemente din tablou
1234
Iesire:
Datele de intrare nu corespund restricțiilor impuse.

Important[edit | edit source]

Soluţia propusă va conţine definiţia subprogramului cerut și eventual al altor subprograme, apelate de acesta. 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]

<syntaxhighlight lang="python" line="1">

def validare_natural(n):

   return n > 0

def validare_dimensiune_tablou(n):

   return n <= 100

def suma_divizibile_cu_3(v, n):

   return sum(x for x in v if x % 3 == 0)

def main():

   try:
       n = int(input("Introduceți numărul de elemente din tablou: "))
       if not validare_natural(n) or not validare_dimensiune_tablou(n):
           raise ValueError
       v = [int(input(f"Introduceți elementul {i+1}: ")) for i in range(n)]
       print("Datele de intrare corespund restricțiilor impuse.")
       print(f"Suma elementelor din tablou care sunt divizibile cu 3 este: {suma_divizibile_cu_3(v, n)}")
   except ValueError:
       print("Datele de intrare nu corespund restricțiilor impuse.")

if __name__ == "__main__":

   main()

</syntaxhighlight>

Explicații[edit | edit source]

Codul scris este o implementare a cerințelor enunțate în problema de mai sus.

Funcția validare_natural verifică dacă un număr este natural nenul (n > 0) și returnează True dacă este, False în caz contrar.

Funcția validare_dimensiune_tablou verifică dacă un număr este mai mic sau egal cu 100 (dimensiunea maximă a tabloului) și returnează True dacă este, False în caz contrar.

Funcția suma_divizibile_cu_3 calculează suma elementelor dintr-un tablou unidimensional care sunt divizibile cu 3 și primește ca parametri v - tabloul unidimensional și n - numărul efectiv de elemente din tablou.

Funcția main este funcția principală care citește datele de intrare și afișează rezultatul sau un mesaj de eroare. Ea folosește funcțiile de validare și de rezolvare pentru a verifica și procesa datele de intrare.

În cadrul funcției main, datele de intrare sunt citite de la tastatură și apoi sunt verificate utilizând funcțiile validare_natural și validare_dimensiune_tablou. Dacă datele de intrare sunt valide, se creează un tablou v care este umplut cu numerele citite de la tastatură și apoi se afișează mesajul "Datele de intrare corespund restricțiilor impuse" și suma elementelor din tablou care sunt divizibile cu 3, calculată utilizând funcția suma_divizibile_cu_3.

În caz contrar, dacă datele de intrare nu sunt valide, se afișează mesajul "Datele de intrare nu corespund restricțiilor impuse".