scala并发编程第一章习题

1.下面的方法签名实现一个compose方法

    def compose[A,B,C](g:B => C ,f : A => B):A => C = x => g(f(x))

思路就是上一篇文章说的关于compose和andThen解读

2.下面一个方法签名实现一个名为fuse的方法:

def fuse[A,B](a:Option[A],b:Option[B]):Option[(A,B)] => for(x <- a;y <- b ) yield (x,y)

3.一个名为check的方法,该方法接收一组类型为T的值和一个T=>Boolean类型的函数,只有函数pred对序列所有值都返回true,该方法返回true

//1
def check[T](xs:Seq[T])(pred:T=>Boolean) :Boolean = xs.filterNot(pred).isEmpty
//2
def check[T](xs:Seq[T])(pred:T=>Boolean) :Boolean = xs.forAll(pred)

4.Pair适合模式匹配

//old
class Pair[P,Q](val first:P,val second:Q)
//new
case class Pair[P,Q](val first:P,val second:Q)

5.一个名为permutations的函数,使该函数接收一个字符串,并返回一个字符串序列,返回的序列为输入字符串字典顺序

def premutations(x:String) : Seq[String] = x.split("").sortBy(_.toLowerCase)

效果截图scala并发编程第一章习题_第1张图片

你可能感兴趣的:(scala,并发)