使用数组作为 Scala foldLeft 累加器
Use an array as a Scala foldLeft accumulator
我正在尝试在数组上使用 foldLeft。例如:
var x = some array
x.foldLeft(new Array[Int](10))((a, c) => a(c) = a(c)+1)
这拒绝编译并发现错误 Int(0) required Array[Int]。
Scala 中的赋值不 return 一个值(而是 Unit)所以你的表达式应该 return Array[Int] 用于下一步 returns Unit这不起作用。
你必须使用一个块和 return 最后的数组,如下所示:
x.foldLeft(new Array[Int](10)) { (a, c) =>
a(c) = a(c)+1
a
}
为了在你想做的事情中使用 foldLeft
,并遵循你的风格,你可以 return 在计算中使用相同的累加器数组,如下所示:
val ret = a.foldLeft(new Array[Int](10)) {
(acc, c) => acc(c) += 1; acc
}
或者,由于您的数字是从 0 到 9,您也可以这样做以获得相同的结果:
val ret = (0 to 9).map(x => a.count(_ == x))
我正在尝试在数组上使用 foldLeft。例如:
var x = some array
x.foldLeft(new Array[Int](10))((a, c) => a(c) = a(c)+1)
这拒绝编译并发现错误 Int(0) required Array[Int]。
Scala 中的赋值不 return 一个值(而是 Unit)所以你的表达式应该 return Array[Int] 用于下一步 returns Unit这不起作用。
你必须使用一个块和 return 最后的数组,如下所示:
x.foldLeft(new Array[Int](10)) { (a, c) =>
a(c) = a(c)+1
a
}
为了在你想做的事情中使用 foldLeft
,并遵循你的风格,你可以 return 在计算中使用相同的累加器数组,如下所示:
val ret = a.foldLeft(new Array[Int](10)) {
(acc, c) => acc(c) += 1; acc
}
或者,由于您的数字是从 0 到 9,您也可以这样做以获得相同的结果:
val ret = (0 to 9).map(x => a.count(_ == x))