如何在Scala中定义一个Lift函数

3

有人能帮我定义这个函数吗:

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

2
也许
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

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接