Files
Yudong Jin 772183705e Add ru version (#1865)
* Add Russian docs site baseline

* Add Russian localized codebase

* Polish Russian code wording

* Update ru code translation.

* Update code translation and chapter covers.

* Fix pythontutor extraction.

* Add README and landing page.

* placeholder of profiles

* Use figures of English version

* Remove chapter paperbook
2026-03-28 04:24:07 +08:00

78 lines
2.6 KiB
Kotlin

/**
* File: recursion.kt
* Created Time: 2024-01-25
* Author: curtishd (1023632660@qq.com)
*/
package chapter_computational_complexity.recursion
import java.util.*
/* Рекурсия */
fun recur(n: Int): Int {
// Условие завершения
if (n == 1)
return 1
// Рекурсивный шаг: рекурсивный вызов
val res = recur(n - 1)
// Возврат: вернуть результат
return n + res
}
/* Имитация рекурсии итерацией */
fun forLoopRecur(n: Int): Int {
// Использовать явный стек для имитации системного стека вызовов
val stack = Stack<Int>()
var res = 0
// Рекурсивный шаг: рекурсивный вызов
for (i in n downTo 0) {
// Имитировать «рекурсию» с помощью операции помещения в стек
stack.push(i)
}
// Возврат: вернуть результат
while (stack.isNotEmpty()) {
// Имитировать «возврат» с помощью операции извлечения из стека
res += stack.pop()
}
// res = 1+2+3+...+n
return res
}
/* Хвостовая рекурсия */
tailrec fun tailRecur(n: Int, res: Int): Int {
// Добавить ключевое слово tailrec, чтобы включить оптимизацию хвостовой рекурсии
// Условие завершения
if (n == 0)
return res
// Хвостовой рекурсивный вызов
return tailRecur(n - 1, res + n)
}
/* Последовательность Фибоначчи: рекурсия */
fun fib(n: Int): Int {
// Условие завершения: f(1) = 0, f(2) = 1
if (n == 1 || n == 2)
return n - 1
// Рекурсивный вызов f(n) = f(n-1) + f(n-2)
val res = fib(n - 1) + fib(n - 2)
// Вернуть результат f(n)
return res
}
/* Driver Code */
fun main() {
val n = 5
var res: Int
res = recur(n)
println("\nРезультат суммирования в рекурсивной функции res = $res")
res = forLoopRecur(n)
println("\nРезультат суммирования при имитации рекурсии итерацией res = $res")
res = tailRecur(n, 0)
println("\nРезультат суммирования в хвостовой рекурсии res = $res")
res = fib(n)
println("\nЧлен последовательности Фибоначчи с номером $n = $res")
}