scala - 用 Scala 将两个列表相乘的函数式风格

标签 scala functional-programming

我正在使用 Scala 2.9,并想根据某些操作构建一个列表。

考虑以下,我有两个简单的列表:

val l1 = 列表(2,3)
val l2 = 列表(列表(4,5,6),列表(7,8,9))

我想要的行为如下,两个列表的操作,如下所示:

(2*4)+(3*7)
(2*5)+(3*8)
(2*6)+(3*9)

结果我想得到另一个包含这些值的列表:29,34,39

我已经尝试用上面的源代码解决了。我可能完全以错误的方式思考这个问题,但我正在努力想出一个优雅的解决方案。

val lr = (l1,l2).zipped.map( (t1:Int, t2:List[Int]) =>
...
)
println (lr)//应该打印 List(29, 34, 39)

然而,我什至不确定我的方式是否正确,或者我应该如何继续。谁能想到一个优雅的解决方案来解决我的问题?

最佳答案

这是一种可能的方式,但我不确定它是否优雅:

l2.transpose.map(sl => (l1, sl).zipped.map{ case(x,y) => x*y }.sum)
res: List[Int] = List(29, 34, 39)

根据@Tharabas 和@michael_s 的评论,我们终于有了更紧凑的解决方案:
l2.transpose.map((l1,_).zipped.map(_*_).sum)

关于scala - 用 Scala 将两个列表相乘的函数式风格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15572315/

相关文章:

scala - 为什么我必须在此函数中包含额外的类型信息

scala - 标记类型中的协方差

Scala:我可以声明一个在编译时不会生成 getter 和 setter 的公共(public)字段吗?

function - SML NJ 的内部函数

c# - 有没有办法用 C# 中的给定比较函数在功能上比较两个已知大小相等的列表?

c++ - 为什么用 std::function 重载函数需要中间变量

scala - Spark : Efficient way to test if an RDD is empty

scala - 通过 Akka HTTP/Akka Streams 转发(下载/上传)大文件

scala - 中断或短路 Scala 中的折叠

c# - 处理函数代码中可变性的策略