首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Scala:( Int,Int) => Int与(Int,Int) => Int不匹配

Scala:( Int,Int) => Int与(Int,Int) => Int不匹配
EN

Stack Overflow用户
提问于 2012-01-21 07:26:25
回答 1查看 3.9K关注 0票数 5

我正在尝试使用y-combinator在scala中定义gcd:

代码语言:javascript
复制
object Main {
  def y[A,B]( f : (A => B) => A => B ) : A => B = f(y(f))
  def gcd = y[(Int,Int),Int]( (g) => (x,y) => if (x == 0) y else g(y % x, x) )
}

但是我得到了一个错误:

代码语言:javascript
复制
Main.scala:3: error: type mismatch;                                                  
 found   : (Int, Int) => Int                                                               
 required: (Int, Int) => Int                                                               
    def gcd = y[(Int,Int),Int]( (g) => (x :Int,y :Int) => if (x == 0) y else g(y % x, x) ) 
                                                       ^

如果我草率处理所有的参数,那么就没有问题了:

代码语言:javascript
复制
def gcd = y[Int,Int => Int]( g => x => y => if (x == 0) y else g(y % x)(x) )

在未加标记的版本中,我做错了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-01-21 07:46:55

使用(g) => (x :Int,y :Int) =>的bit。Scala希望您的参数是(Int,Int)的元组,所以它更像(g) => (tup: (Int, Int)) =>

您可以使用一些模式匹配来避免在tup上使用_1_2匹配。这段代码对我来说编译得很好:

代码语言:javascript
复制
def gcd = y[(Int, Int), Int](g => {
  case (x,y) => if(x == 0) y else g(y % x, x)
})
票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8949157

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档