TypeScript 杂记九 《Integers Comparator》

TypeScript 杂记九 《Integers Comparator》

Integers Comparator

思路

参考这篇文章中的思路:TypeScript 杂记五 《Sort》

完整示例


type Reverser<T> = T extends 1 ? -1 : T extends 0 ? 0 : 1

type StringToArray<T extends string, RR extends string[] = []> = T extends `${infer L}${infer R}`
  ? StringToArray<R, [...RR, L]>
  : RR

type Compare<A, B, H extends unknown[] = []> = `${H['length']}` extends A
  ? `${H['length']}` extends B
    ? 0
    : -1
  : `${H['length']}` extends B
  ? 1
  : Compare<A, B, [...H, unknown]>

type CompareArrayHelper<A, B> = A extends [infer AL, ...infer AR]
  ? B extends [infer BL, ...infer BR]
    ? Compare<AL, BL> extends 0
      ? CompareArrayHelper<AR, BR>
      : Compare<AL, BL>
    : 0
  : 0

type CompareArray<
  A extends string[],
  B extends string[],
  H extends unknown[] = [],
> = H['length'] extends A['length']
  ? H['length'] extends B['length']
    ? CompareArrayHelper<A, B>
    : -1
  : H['length'] extends B['length']
  ? 1
  : CompareArray<A, B, [...H, unknown]>

type ComparatorHelper<A extends string, B extends string> = A extends `-${infer _A}`
  ? B extends `-${infer _B}`
    ? Reverser<CompareArray<StringToArray<_A>, StringToArray<_B>>>
    : -1
  : B extends `-${string}`
  ? 1
  : CompareArray<StringToArray<A>, StringToArray<B>>

type Comparator<A extends number | bigint, B extends number | bigint> = ComparatorHelper<
  `${A}`,
  `${B}`
> extends 1
  ? Comparison.Greater
  : ComparatorHelper<`${A}`, `${B}`> extends 0
  ? Comparison.Equal
  : Comparison.Lower

测试


type Test1 = Comparator<1, 2> // Comparison.Lower
type Test11 = Comparator<1, -2222> // Comparison.Greater
type Test111 = Comparator<-1, -2> // Comparison.Greater
type Test2 = Comparator<1_000_000_000_000n, 1_000_000_000_000n> // Comparison.Equal
type Test3 = Comparator<1_000_000_000_000n, 1_000_000_000_001n> // Comparison.Lower
type Test4 = Comparator<1_000_000_000_100n, 1_000_000_000_001n> // Comparison.Greater
type Test5 = Comparator<-1_000_000_000_100n, -1_000_000_000_001n> // Comparison.Lower
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值