[Typescript] 83. Medium - Subsequence

Given an array of unique elements, return all possible subsequences.

A subsequence is a sequence that can be derived from an array by deleting some or no elements without changing the order of the remaining elements.

For example:

type A = Subsequence<[1, 2]> // [] | [1] | [2] | [1, 2]
/* _____________ Your Code Here _____________ */

type Subsequence<T extends any[]> = T extends [infer F, ...infer RT]
  ? Subsequence<RT> | [F, ...Subsequence<RT>]
  : []

/* _____________ Test Cases _____________ */
import type { Equal, Expect } from '@type-challenges/utils'

type cases = [
  Expect<Equal<Subsequence<[1, 2]>, [] | [1] | [2] | [1, 2]>>,
  Expect<Equal<Subsequence<[1, 2, 3]>, [] | [1] | [2] | [1, 2] | [3] | [1, 3] | [2, 3] | [1, 2, 3] >>,
]

 

posted @   Zhentiw  阅读(19)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2019-10-31 [Kubernetes] Pod Health
2019-10-31 [React] Write a Custom State Hook in React
2019-10-31 [React] Use the React Effect Hook in Function Components
2017-10-31 [RxJS] Marbles Testings
2016-10-31 [Angular2Fire] Firebase auth (Google, Github)
点击右上角即可分享
微信分享提示