[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 @   Zhentiw  阅读(10)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2021-10-21 [AWS] RTO & RPO
2020-10-21 [Kotlin] Compare Functional Programming in Java and Kotlin
2020-10-21 [Kotlin] Catch Error in Java
2019-10-21 [VSCode] Custom settings
2019-10-21 [Flutter] Use http package to get data from network
2018-10-21 [Rust] Pass a JavaScript Function to WebAssembly and Invoke it from Rust
2018-10-21 [React] Extend styles with styled-components in React
点击右上角即可分享
微信分享提示