1847 - VectorSumPrim REC
Cerinţa
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
Se va introduce de la tastatură un număr natural care va fi transmis ca perimetru
Date de ieșire
Pe ecran se va afișa mesajul: "Datele de intrare corespund restricțiilor impuse." Î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
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
Dacă n=6 și x=(12, 7, 6, 3, 8, 5), după apel s=15.
Important
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
- Funcția de validare:
def validare_natural(n): Verifică dacă un număr este natural nenul (n > 0). Returnează True dacă este, False în caz contrar. return n > 0 def validare_dimensiune_tablou(n): Verifică dacă un număr este mai mic sau egal cu 100 (dimensiunea maximă a tabloului). Returnează True dacă este, False în caz contrar. return n <= 100
- Funcția de rezolvare:
def suma_divizibile_cu_3(v, n): #Calculează suma elementelor dintr-un tablou unidimensional care sunt divizibile cu 3. #Parametri: v: tabloul unidimensional (list) 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: 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 = [] 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(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.")
- Funcția de validare:
def validare_natural(n): #Verifică dacă un număr este natural nenul (n > 0). #Returnează True dacă este, False în caz contrar. return n > 0 def validare_dimensiune_tablou(n): #Verifică dacă un număr este mai mic sau egal cu 100 (dimensiunea maximă a tabloului). #Returnează True dacă este, False în caz contrar. return n <= 100
- Funcția de rezolvare:
def suma_prime(x, n, s=0, i=0): #Calculează suma elementelor prime dintr-un tablou unidimensional. #Parametri: x: tabloul unidimensional (list) n: numărul de elemente din tablou (int) s: suma elementelor prime din tabl