V tomto príklade sa naučíte nájsť súčet prirodzených čísel pomocou rekurzívnej funkcie.
Aby ste pochopili tento príklad, mali by ste mať znalosti nasledujúcich tém programovania v jazyku C:
- C Užívateľom definované funkcie
- C Rekurzia
Kladné čísla 1, 2, 3… sú známe ako prirodzené čísla. Program uvedený nižšie vezme od používateľa kladné celé číslo a vypočíta súčet až po dané číslo.
Navštívte túto stránku a nájdite súčet prirodzených čísel pomocou slučky.
Súčet prirodzených čísel pomocou rekurzie
#include int addNumbers(int n); int main() ( int num; printf("Enter a positive integer: "); scanf("%d", &num); printf("Sum = %d", addNumbers(num)); return 0; ) int addNumbers(int n) ( if (n != 0) return n + addNumbers(n - 1); else return n; )
Výkon
Zadajte kladné celé číslo: 20 Súčet = 210
Predpokladajme, že používateľ zadal 20.
Spočiatku addNumbers()
je volaný z main()
čísla 20 a prešiel ako argument.
Číslo 20 sa pripočíta k výsledku addNumbers(19)
.
V nasledujúcom volaní funkcie od addNumbers()
do addNumbers()
je odovzdané 19, ktoré sa pripočítajú k výsledku addNumbers(18)
. Tento proces pokračuje, kým n sa nerovná 0.
Keď je n rovné 0, neexistuje rekurzívne volanie. Toto vráti súčet celých čísel nakoniec do main()
funkcie.