给定例如:
List(5,2,3,5,2)
我想去:
List(List(5),List(2),List(3,3),List(5,5),List(2,2))
解决方法
这是我通常使用的技巧:
def split[T](list: List[T]) : List[List[T]] = list match { case Nil => Nil case h::t => val segment = list takeWhile {h ==} segment :: split(list drop segment.length) }
实际上…不是,我通常抽象超过收集类型,并优化与尾递归,但想保持答案简单.