3279313f2c
See K1 counterpart at org.jetbrains.kotlin.resolve.calls.tower.TowerResolver.Task.processImplicitReceiver ^KT-58943 Fixed ^KT-59541 Fixed
44 lines
969 B
Kotlin
Vendored
44 lines
969 B
Kotlin
Vendored
// WITH_STDLIB
|
|
|
|
fun box(): String {
|
|
Nat<Int>(
|
|
nil = 0,
|
|
next = { this + 1 }
|
|
).run {
|
|
val fib = fibonacci(10)
|
|
if (fib != 89)
|
|
return "Failed: $fib"
|
|
}
|
|
|
|
return "OK"
|
|
}
|
|
|
|
fun <T> Nat<T>.fibonacci(
|
|
n: T,
|
|
seed: Pair<T, T> = nil to one,
|
|
fib: (Pair<T, T>) -> Pair<T, T> = { (a, b) -> b to a + b },
|
|
i: T = nil,
|
|
): T =
|
|
if (i == n) fib(seed).first
|
|
else fibonacci(n = n, seed = fib(seed), i = i.next())
|
|
|
|
|
|
tailrec fun <T> Nat<T>.plus(l: T, r: T, acc: T = l, i: T = nil): T =
|
|
if (i == r) acc else plus(l, r, acc.next(), i.next())
|
|
|
|
interface Nat<T> {
|
|
val nil: T
|
|
val one: T get() = nil.next()
|
|
|
|
fun T.next(): T
|
|
operator fun T.plus(t: T) = plus(this, t)
|
|
|
|
companion object {
|
|
operator fun <T> invoke(nil: T, next: T.() -> T): Nat<T> =
|
|
object: Nat<T> {
|
|
override val nil: T = nil
|
|
override fun T.next(): T = next()
|
|
}
|
|
}
|
|
}
|