开发者

safe Iterator.max

开发者 https://www.devze.com 2023-04-01 05:04 出处:网络
Is there a library that offers a function like Iterator.max开发者_Python百科, but that returns an Option[A] rather than an A to account for possibly-empty iterators? Alternately, is there a library th

Is there a library that offers a function like Iterator.max开发者_Python百科, but that returns an Option[A] rather than an A to account for possibly-empty iterators? Alternately, is there a library that offers a class PosInf[A] or so that adjoins a positive infinity to A?

(Obviously either of these is mere gruntwork to do myself, but using a library is almost always preferable to duplicating code.)


scalaz: MA.maximum. Usage:

import scalaz._; import Scalaz._

List(1, 2, 3).maximum == Some(3)

List.empty[Int].maximum == None

the only problem is that this does not work with Iterators directly, so you would have to use a Stream instead (e.g. using Iterator.toStream)

List(1, 2, 3).iterator.toStream.maximum = Some(3)


I'm not aware of anything but this is simple:

def maxOpt[T: Numeric](i: Iterator[T]) = if (i.hasNext) Some(i.max) else None

Edit: Numeric is too strong a requirement, Ordering is enough:

def maxOpt[T: Ordering](i: Iterator[T]) = if (i.hasNext) Some(i.max) else None

And if you use isEmpty is should work on any subclass of TraversableOnce

0

精彩评论

暂无评论...
验证码 换一张
取 消