В этой программе вы научитесь вычислять степень числа с помощью рекурсивной функции в Kotlin.
Пример: программа для расчета мощности с использованием рекурсии
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 )
Когда вы запустите программу, вывод будет:
3 4 = 81
В приведенной выше программе вы вычисляете мощность с помощью рекурсивной функции power ().
Проще говоря, рекурсивная функция умножает базу на себя для powerRaised times, что составляет:
3 * 3 * 3 * 3 = 81Шаги выполнения
Итерация | мощность() | powerRaised | результат |
---|---|---|---|
1 | мощность (3, 4) | 4 | 3 * результат 2 |
2 | мощность (3, 3) | 3 | 3 * 3 * результат 3 |
3 | мощность (3, 2) | 2 | 3 * 3 * 3 * результат 4 |
4 | мощность (3, 1) | 1 | 3 * 3 * 3 * 3 * результат окончательный |
Финал | мощность (3, 0) | 0 | 3 * 3 * 3 * 3 * 1 = 81 |
Вот эквивалентный код Java: Программа Java для расчета мощности с использованием рекурсии