groupMapReduce
方法(或属性)属于 scala.collection.LinearSeqOps
特性(trait),其相关用法说明如下。
用法:
def groupMapReduce[K, B](key: A => K)(f: A => B)(reduce: (B, B) => B): Map[K, B]
根据鉴别函数key
将此可迭代集合划分为映射.然后,所有具有相同鉴别器的值由f
函数转换,然后使用reduce
函数简化为单个值。
它等效于 groupBy(key).mapValues(_.map(f).reduce(reduce))
,但效率更高。
def occurrences[A](as: Seq[A]): Map[A, Int] =
as.groupMapReduce(identity)(_ => 1)(_ + _)
注意:即使应用于视图或惰性集合,它也会始终强制元素。
相关用法
- Scala LinearSeqOps.groupMapReduce用法及代码示例
- Scala LinearSeqOps.groupMap用法及代码示例
- Scala LinearSeqOps.groupBy用法及代码示例
- Scala LinearSeqOps.sizeIs用法及代码示例
- Scala LinearSeqOps.appended用法及代码示例
- Scala LinearSeqOps.partitionMap用法及代码示例
- Scala LinearSeqOps.collectFirst用法及代码示例
- Scala LinearSeqOps.addString用法及代码示例
- Scala LinearSeqOps.sliding用法及代码示例
- Scala LinearSeqOps.scanRight用法及代码示例
- Scala LinearSeqOps.sortWith用法及代码示例
- Scala LinearSeqOps.sortBy用法及代码示例
- Scala LinearSeqOps.inits用法及代码示例
- Scala LinearSeqOps.combinations用法及代码示例
- Scala LinearSeqOps.unzip用法及代码示例
- Scala LinearSeqOps.prepended用法及代码示例
- Scala LinearSeqOps.mkString用法及代码示例
- Scala LinearSeqOps.unzip3用法及代码示例
- Scala LinearSeqOps.transpose用法及代码示例
- Scala LinearSeqOps.lengthIs用法及代码示例
- Scala LinearSeqOps.permutations用法及代码示例
- Scala LinearSeq.elementWise用法及代码示例
- Scala LinearSeq.permutations用法及代码示例
- Scala LinearSeq.appended用法及代码示例
- Scala LinearSeq.unzip3用法及代码示例
注:本文由纯净天空筛选整理自scala-lang.org大神的英文原创作品 LinearSeqOps.groupMapReduce。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。