【问题标题】:Finding common factors in Scala在 Scala 中寻找公因数
【发布时间】:2017-04-14 01:55:40
【问题描述】:

我们需要找到整数列表的所有公因数:

val b = List(4, 8, 12)
b: List[Int] = List(4, 8, 12)

获取列表中的最小值:

val min_b = b.min
min_b: Int = 4

遍历从 1 到 min_b 的范围并检查 b 中的每个元素是否可以被迭代器的当前值整除,但输出包含空 AnyVals

val factors_of_b = (1 to min_b)
  .map { x => if (b.forall{ z => z % x == 0 }) x }

结果:

factors_of_b: scala.collection.immutable.IndexedSeq[AnyVal] = Vector(1, 2, (), 4)

用零代替不适用的因素并将结果过滤为零是一种解决方法,但也许存在一种更清洁、更类似于 Scala 的解决方案?

val factors_of_b = (1 to min_b)
  .map { x => if(b.forall{ z => z % x == 0 }) x else 0 }
  .filterNot(_ == 0)

结果:

factors_of_b: scala.collection.immutable.IndexedSeq[Int] = Vector(1, 2, 4)

【问题讨论】:

  • 为了正确格式化较大的代码片段,缩进四个空格。背包适用于小的单行代码。

标签: scala functional-programming factors


【解决方案1】:

你想要的是filter:

scala> val b = List(4, 8, 12)
b: List[Int] = List(4, 8, 12)

scala> (1 to b.max).filter { x => b.forall{ z => z % x == 0 } }
res3: scala.collection.immutable.IndexedSeq[Int] = Vector(1, 2, 4)

另外,我不确定您为什么要迭代到 b.max 而不是 b.min,因为公因数不会大于任何数字。

【讨论】:

  • 非常感谢!当然是 b.min - 我的错。相应更新。
猜你喜欢
  • 2019-01-19
  • 2021-01-18
  • 1970-01-01
  • 2021-07-16
  • 2020-07-29
  • 1970-01-01
  • 2021-10-14
  • 2010-12-27
  • 2011-08-01
相关资源
最近更新 更多