首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何选择乘法幺半群而不是加法幺半群?

如何选择乘法幺半群而不是加法幺半群?
EN

Stack Overflow用户
提问于 2014-10-22 08:38:11
回答 1查看 246关注 0票数 5

我想合并两份名单:

代码语言:javascript
复制
import scalaz.syntax.align._
import scalaz.std.list._
import scalaz.std.anyVal._

List(1, 2, 3).merge(List(4, 5, 6, 7)) // Evaluates to List(5, 7, 9, 7)

这将隐式地使用标准加法单半群。如果我想用乘法幺半群代替呢?用Scalaz做这件事的惯用方法是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-10-22 09:11:39

您可以使用Multiplication标记来指示要使用乘法幺半群:

代码语言:javascript
复制
import scalaz.Tags.Multiplication

val xs = List(1, 2, 3).map(Multiplication(_))
val ys = List(4, 5, 6, 7).map(Multiplication(_))

然后:

代码语言:javascript
复制
scala> xs merge ys
res0: List[scalaz.@@[Int,scalaz.Tags.Multiplication]] = List(4, 10, 18, 7)

Multiplication.unwrap移除标记。

您还可以显式传递您自己的实例:

代码语言:javascript
复制
scala> List(1, 2, 3).merge(List(4, 5, 6, 7))(Monoid.instance(_ * _, 1))
res1: List[Int] = List(4, 10, 18, 7)

不过,使用标记更有习性。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26503385

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档