0116 - Medie Prime: Difference between revisions
Paul Matei (talk | contribs) |
Diana Butuza (talk | contribs) |
||
(9 intermediate revisions by 2 users not shown) | |||
Line 4: | Line 4: | ||
Programul citește de la tastatură numărul '''numar''', iar apoi '''n''' numere naturale.. | Programul citește de la tastatură numărul '''numar''', iar apoi '''n''' numere naturale.. | ||
== Date de ieşire == | == Date de ieşire == | ||
Programul afișează pe ecran numărul M, reprezentând media aritmetică a valorilor prime. | Programul afișează pe ecran numărul '''M''', reprezentând media aritmetică a valorilor prime. | ||
== Restricții și precizări == | == Restricții și precizări == | ||
* numar ∈ Ν | * numar ∈ Ν | ||
* 0 ⩽ n ⩽ 1.000 | * 0 ⩽ n ⩽ 1.000 | ||
* cele n numere citite vor fi mai mici decât 10000 | * cele n numere citite vor fi mai mici decât 10000 | ||
*rezultatul se va afişa cu cel puțin două zecimale exacte | *rezultatul se va afişa cu cel puțin două zecimale exacte | ||
* | *printre cele n numere va exista cel puțin un număr prim | ||
== Exemplu == | == Exemplu == | ||
; Intrare | ; Intrare | ||
Line 16: | Line 18: | ||
: 8 7 5 9 11 | : 8 7 5 9 11 | ||
; Ieșire | ; Ieșire | ||
: Datele | : Datele de intrare corespund restricțiilor impuse. | ||
: 7. | : 7.666666666666667 | ||
== Rezolvare == | == Rezolvare == | ||
<syntaxhighlight lang="python" line> | <syntaxhighlight lang="python" line> | ||
Line 32: | Line 35: | ||
return False | return False | ||
def | def este_prim(numar): | ||
if numar < 2: | if numar < 2: | ||
return False | return False | ||
Line 40: | Line 43: | ||
return True | return True | ||
def | def lista_numere_prime(numere): | ||
numere_prime = [numar for numar in numere if este_prim(numar)] | |||
if len( | if len(numere_prime) > 0: | ||
return sum( | return sum(numere_prime) / len(numere_prime) | ||
else: | else: | ||
return None | return None | ||
Line 54: | Line 57: | ||
if validare_date_numere(str(len(numere))): | if validare_date_numere(str(len(numere))): | ||
print("Datele de intrare corespund restricțiilor impuse.") | print("Datele de intrare corespund restricțiilor impuse.") | ||
rezultat = lista_numere_prime(numere) | |||
if | if rezultat is not None: | ||
print("Media aritmetica a numerelor prime din lista este:", | print("Media aritmetica a numerelor prime din lista este:", rezultat) | ||
else: | else: | ||
print("Nu exista numere prime in lista!") | print("Nu exista numere prime in lista!") | ||
Line 65: | Line 68: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
==Explicație rezolvare== | |||
Programul începe prin definirea a trei funcții: | |||
1.'''validare_date_numar(numar)''': Această funcție verifică dacă un șir de caractere numar dat poate fi convertit la un număr întreg între 0 și 1000. Ea returnează '''True''' dacă condiția este satisfăcută și '''False''' în caz contrar. | |||
2.'''validare_date_numere(n)''': Această funcție verifică dacă un șir de caractere n dat poate fi convertit la un număr întreg între 0 și 10000. Ea returnează '''True''' dacă condiția este satisfăcută și '''False''' în caz contrar. | |||
3.'''este_prim(numar)''': Această funcție verifică dacă un număr întreg dat numar este un număr prim. Ea returnează '''True''' dacă numărul este prim și '''False''' în caz contrar. | |||
După definirea acestor funcții, se verifică dacă introducerea primită de la utilizator este validă, apoi calculează media aritmetică a numerelor prime din lista utilizând funcția '''lista_numere_prime'''. Dacă nu există numere prime în listă, se returnează un mesaj care indică acest lucru. |
Latest revision as of 09:41, 10 April 2023
Cerinţa[edit | edit source]
Să se scrie un program care citeşte de la tastatură un număr natural numar şi apoi un şir de n numere naturale şi determină media aritmetică a celor prime.
Date de intrare[edit | edit source]
Programul citește de la tastatură numărul numar, iar apoi n numere naturale..
Date de ieşire[edit | edit source]
Programul afișează pe ecran numărul M, reprezentând media aritmetică a valorilor prime.
Restricții și precizări[edit | edit source]
- numar ∈ Ν
- 0 ⩽ n ⩽ 1.000
- cele n numere citite vor fi mai mici decât 10000
- rezultatul se va afişa cu cel puțin două zecimale exacte
- printre cele n numere va exista cel puțin un număr prim
Exemplu[edit | edit source]
- Intrare
- 5
- 8 7 5 9 11
- Ieșire
- Datele de intrare corespund restricțiilor impuse.
- 7.666666666666667
Rezolvare[edit | edit source]
<syntaxhighlight lang="python" line> def validare_date_numar(numar):
if numar.isdigit(): if 0 <= int(numar) <= 1000: return True return False
def validare_date_numere(n):
if n.isdigit(): if 0 <= int(n) <= 10000: return True return False
def este_prim(numar):
if numar < 2: return False for i in range(2, int(numar ** 0.5) + 1): if numar % i == 0: return False return True
def lista_numere_prime(numere):
numere_prime = [numar for numar in numere if este_prim(numar)] if len(numere_prime) > 0: return sum(numere_prime) / len(numere_prime) else: return None
if __name__ == "__main__":
n = input("Introduceti numarul de elemente: ") if validare_date_numere(n): print("Datele de intrare corespund restricțiilor impuse.") numere = list(map(int, input("Introduceti numerele: ").split())) if validare_date_numere(str(len(numere))): print("Datele de intrare corespund restricțiilor impuse.") rezultat = lista_numere_prime(numere) if rezultat is not None: print("Media aritmetica a numerelor prime din lista este:", rezultat) else: print("Nu exista numere prime in lista!") else: print("Numarul de numere introdus nu corespunde cu numarul specificat anterior.") else: print("Numarul de elemente introdus nu corespunde cu restrictiile impuse.")
</syntaxhighlight>
Explicație rezolvare[edit | edit source]
Programul începe prin definirea a trei funcții:
1.validare_date_numar(numar): Această funcție verifică dacă un șir de caractere numar dat poate fi convertit la un număr întreg între 0 și 1000. Ea returnează True dacă condiția este satisfăcută și False în caz contrar.
2.validare_date_numere(n): Această funcție verifică dacă un șir de caractere n dat poate fi convertit la un număr întreg între 0 și 10000. Ea returnează True dacă condiția este satisfăcută și False în caz contrar.
3.este_prim(numar): Această funcție verifică dacă un număr întreg dat numar este un număr prim. Ea returnează True dacă numărul este prim și False în caz contrar.
După definirea acestor funcții, se verifică dacă introducerea primită de la utilizator este validă, apoi calculează media aritmetică a numerelor prime din lista utilizând funcția lista_numere_prime. Dacă nu există numere prime în listă, se returnează un mesaj care indică acest lucru.