A classificação de mesclagem de “Programming Scala” causa estouro de pilha

Um recorte e colar direto do seguinte algoritmo:

def msort[T](less: (T, T) => Boolean)
            (xs: List[T]): List[T] = {
  def merge(xs: List[T], ys: List[T]): List[T] =
    (xs, ys) match {
      case (Nil, _) => ys
      case (_, Nil) => xs
      case (x :: xs1, y :: ys1) =>
        if (less(x, y)) x :: merge(xs1, ys)
        else y :: merge(xs, ys1)
    }
  val n = xs.length / 2
  if (n == 0) xs
  else {
    val (ys, zs) = xs splitAt n
     merge(msort(less)(ys), msort(less)(zs))
  }
}

causa um StackOverflowError em 5000 listas longas.

Existe alguma maneira de otimizar isso para que isso não ocorra?

questionAnswers(3)

yourAnswerToTheQuestion