1. feladat: Kérjen be a felhasználótól egy számot (n) írassa ki az n faktoriálist, használjon rekurzív függvényt.
#include <stdio.h> unsigned long long factorial(int n) { if(n == 0) { return 1; } else { return n * factorial(n - 1); } } int main() { int n; printf("Melyik szam faktorialisat szamoljam?"); scanf("%d", &n); printf("%d! = %llu", n, factorial(n)); }2. feladat: Kérjen be a felhasználótól egy számot (n) írassa ki a Fibonacci sorozat első n. elemét egy függvény segítségével.
(0, 1, 1, 2, 3, 5, 8, 14, 22, …) Minden szám az előző kettő összege, kivétel az első kettő, ami f(0) = 0, f(1) = 1.
#include <stdio.h> void fibonacci(int n) { int t1 = 0, t2 = 1, kovetkezo; for (int i = 1; i <= n; ++i) { printf("%d, ", t1); kovetkezo = t1 + t2; t1 = t2; t2 = kovetkezo; } } int main() { int n; printf("Hany elemet irjak ki a Fibonacci sorozatbol?"); scanf("%d", &n); fibonacci(n); }
3. feladat: Kérjen be a felhasználótól egy számot (n) írassa ki a Fibonacci sorozat n. elemét. Használjon rekurziót!
#include <stdio.h> int fibonacci(int n) { if(n == 0 || n == 1) { return n; } else { return(fibonacci(n-1) + fibonacci(n-2)); } } int main() { int n; printf("Hanyadik elemet irjam ki a Fibonacci sorozatnak?"); scanf("%d", &n); printf("%d", fibonacci(n)); }
4. feladat: Adott egy 10 elemű vektor. Kérje be a felhasználótól a 'min' vagy 'max' szavak egyikét. Írassa ki a legkisebb vagy legnagyobb elemet, használjon függvényre mutató pointert függvény argumentumként.
#include <stdio.h> int min(int a, int b) { if(a < b) { return 1; } return 0; } int max(int a, int b) { if(a > b) { return 1; } return 0; } int valaszt(int(f)(int a, int b), int *v, int n) { int x = v[0]; for(int i = 1; i < n; i++) { if(f(v[i], x)) { x = v[i]; } } return x; } int main() { int v[] = {12,1,23,43,243,2,-1,2,3,55}; char s[10]; printf("min vagy max elem?"); scanf("%s", s); if(s[1] == 'i') { printf("min = %d", valaszt(min, v, 10)); } else { printf("min = %d", valaszt(max, v, 10)); } }