Как разрешить несоответствие типов в scala - PullRequest
0 голосов
/ 06 мая 2020

Мне нужна помощь с этим кодом в scala, я хочу реализовать метод foldL, но получаю это:

asd.scala:73: error: type mismatch;
 found   : Option[MyTree[A]] => B
 required: B
      def myFoldLeft[B](z: B)(op: (B, A) => B): B = (_:Option[MyTree[A]]) match {
                                                                          ^
one error found

Я знаю, что это несоответствие типа, но im newb ie с scala и ориентированный объект, и я не понимаю, как разрешить эту ситуацию.

class MyTree[A](val value: A, val left:Option[MyTree[A]],
                              val right:Option[MyTree[A]]) {

  def myFoldLeft[B](z: B)(op: (B, A) => B): B = (_:Option[MyTree[A]]) match {
    case Some(tree) => right.get.myFoldLeft (left.get.myFoldLeft (op(z, value)) (op)) (op)
    case None => z
  }
}

1 Ответ

1 голос
/ 06 мая 2020

(_:Option[MyTree[A]]) ... - лямбда.

Вы должны соответствовать как

class MyTree[A](val value: A, val left:Option[MyTree[A]],
                val right:Option[MyTree[A]]) {    
  def myFoldLeft[B](z: B)(op: (B, A) => B): B = (left, right) match {
    case (Some(left), Some(right)) => ???
    case (Some(left), None) => ???
    case (None, Some(right)) => ???
    case (None, None) => ???
  }
}
...