首页 > 解决方案 > 如何在 Scala 中定义提升函数

问题描述

有人可以帮我,如何定义这个函数:

def lift[A, B, T](op: (T,T) => T)(f: A => T, g: B => T): (A,B) => T = /* ... */

标签: scala

解决方案


也许

def lift[A, B, T](op: (T,T) => T)(f: A => T, g: B => T): (A,B) => T =
  (a: A, b: B) => op(f(a), g(b))

这使

def op(a: Int, b: Int): Int = a + b
def f(x: String): Int = x.toInt
def g(x: List[String]): Int = x.length

lift(op)(f,g)("41", List("2"))
// Int = 42

推荐阅读