scala map方法

递归方法:

def map[A,B](seq:Seq[B],f:B=>A):Seq[A]={

seq match {

case Nil=>Nil

case a +: as =>map(as,f)+:f(a)

}

}

由于是Seq[B]的内部方法,所以通常形式是这样的:

def map[B,That](f:B=>That):Seq[That]={

...

}

尾递归的实现模式:

def _map[A,B](seq:Seq[B],f:B=>A):Seq[A]={

def go(as:Seq[A],seq:Seq[B]):Seq[A]={

seq match {

case Nil=>as

case b +: bs =>go(as +: f(b),bs)

}

go(Nil,seq)

}


}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容