Nu obții 100 de puncte sau ai nelămuriri în privința problemelor? Scrie-mi pe Instagram.
Ai găsit o greșeală, vrei să raportezi un utilizator sau vrei să comunici altceva? Folosește formularul de contact.
Vrei să ne transmiți o părere despre platformă? Folosește formularul de feedback.
Folosește următoarele shortcuturi pentru a naviga mai ușor pe platformă.
Meniu shortcuturi | ? |
Căutare probleme sau utilizatori | / |
Navigare printre rezultatele căutării | ↑, ↓ |
Meniu de contact și feedback | CTRL + Shift + F |
Ieșire din meniuri | Esc |
Setări editor | CTRL + Shift + S |
Schimbare stil editor | CTRL + Shift + E |
Șabloane de cod | CTRL + Shift + 1/2/3 |
Golire editor | CTRL + Shift + 4 |
Dându-se un șir a[]
cu n
elemente, să se afișeze pe ecran suma elementelor sale, folosind o funcție recursivă.
Exemplu. Pentru a = (1, 2, 10, 9, 8)
, pe ecran se afișează 30
.
Vom crea un subprogram care are ca parametri următorii:
a
);n
);i
);Vom simula o structură repetitivă de tip for
, astfel:
i ≤ n
, atunci:a[i]
), la care adunăm suma elementelor de după (apelând funcția pentru i + 1
);i > n
):0
și ne oprim.Vom indexa șirul de la 1
, însă rezolvarea este foarte asemănătoare și pentru indexarea de la 0
.
Iată rezolvarea în C++.
#include <iostream>
using namespace std;
int sumaElementelor(int a[], int n, int i) { //Șirul, lungimea și indicele curent
if(i > n) { //Dacă am terminat șirul, atunci ne oprim din executat
return 0; //Similar cu break
}
return a[i] + sumaElementelor(a, n, i + 1); //Returnăm elementul curent + suma elementelor de după
}
int main()
{
//Declarăm și citim șirul nostru (indexat de la 1)
int n, a[101];
cin >> n;
for(int i = 1; i <= n; i++) {
cin >> a[i];
}
//Afișăm suma elementelor șirului
cout << sumaElementelor(a, n, 1);
return 0;
}