[Typescript] 62. Medium - Fibonacci Sequence

Implement a generic Fibonacci<T> that takes a number T and returns its corresponding Fibonacci number.

The sequence starts: 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, ...

For example

type Result1 = Fibonacci<3> // 2
type Result2 = Fibonacci<8> // 21

 

/**
 * list[n - 1] + list[n - 2] = list[n]
 * C 记录计算到第几个了
 * U1 记录第C个斐波那契值
 * U2 记录第C + 1个斐波那契值
 */
type Fibonacci<T extends number, C extends unknown[] = [], U1 extends unknown[] = [], U2 extends unknown[] = [unknown]> = T extends C['length']
  ? U1['length']
  : Fibonacci<T, [unknown, ...C], U2, [...U1, ...U2]>

 

posted @ 2022-10-21 18:40  Zhentiw  阅读(14)  评论(0)    收藏  举报