Selles programmis saate õppida arvu võimsust arvutama Kotlini rekursiivse funktsiooni abil.
Näide: programm rekursiooni abil võimsuse arvutamiseks
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 )
Programmi käivitamisel on väljund järgmine:
3 4 = 81
Ülaltoodud programmis arvutate võimsuse rekursiivse funktsiooni võimsuse () abil.
Lihtsamalt öeldes korrutab rekursiivne funktsioon aluse iseendaga powerRaised aegade jaoks, mis on:
3 * 3 * 3 * 3 = 81Täitmise etapid
Kordus | võimsus () | powerRaised | tulemus |
---|---|---|---|
1 | võimsus (3, 4) | 4 | 3 * tulemus 2 |
2 | võimsus (3, 3) | 3 | 3 * 3 * tulemus 3 |
3 | võimsus (3, 2) | 2 | 3 * 3 * 3 * tulemus 4 |
4 | võimsus (3, 1) | 1 | 3 * 3 * 3 * 3 * tulemuse finaal |
Lõplik | võimsus (3, 0) | 0 | 3 * 3 * 3 * 3 * 1 = 81 |
Siin on samaväärne Java kood: Java-programm rekursiooni abil võimsuse arvutamiseks