U ovom ćete programu naučiti izračunavati snagu broja pomoću rekurzivne funkcije u Kotlinu.
Primjer: Program za izračunavanje snage pomoću rekurzije
fun main(args: Array) ( val base = 3 val powerRaised = 4 val result = power(base, powerRaised) println("$base^$powerRaised = $result") ) fun power(base: Int, powerRaised: Int): Int ( if (powerRaised != 0) return base * power(base, powerRaised - 1) else return 1 )
Kada pokrenete program, izlaz će biti:
3 4 = 81
U gornjem programu izračunate snagu pomoću rekurzivne funkcije power ().
Jednostavnim riječima, rekurzivna funkcija množi bazu sa sobom za vrijeme porasta snage, a to je:
3 * 3 * 3 * 3 = 81Koraci izvršenja
Iteracija | vlast() | snagaPodignuta | proizlaziti |
---|---|---|---|
1 | snaga (3, 4) | 4 | 3 * rezultat 2 |
2 | snaga (3, 3) | 3 | Rezultat 3 * 3 * 3 |
3 | snaga (3, 2) | 2 | Rezultat 3 * 3 * 3 * 4 |
4 | snaga (3, 1) | 1 | 3 * 3 * 3 * 3 * konačni rezultat |
Konačno | snaga (3, 0) | 0 | 3 * 3 * 3 * 3 * 1 = 81 |
Evo ekvivalentnog Java koda: Java program za izračunavanje snage pomoću rekurzije