如何使用Scala有效地获取给定二进制字符串的1s索引?

时间:2015-06-22 06:58:54

标签: scala functional-programming higher-order-functions

假设我们有一个二进制字符串,例如10010010

我想要的只是一个函数,为该字符串返回1 s的索引:

indicesOfOnes("10010010") -> List(0, 3, 6)
indicesOfOnes("0") -> List()

我实施的是:

def indicesOfOnes(bs: String): List[Int] = {
  val lb = ListBuffer[Int]()
  bs.zipWithIndex.foreach { case (v, i) =>
    if (v == '1') {
      lb += i
    }
  }
  lb.toList
}

这是有效的,但我认为有更好的(更多功能)方法来完成这项工作。任何建议将不胜感激。

1 个答案:

答案 0 :(得分:10)

您可以使用filter然后使用map来获取索引:

scala> val s = "10010010"
s: String = 10010010

scala> s.zipWithIndex.withFilter(_._1 == '1').map(_._2)
res0: scala.collection.immutable.IndexedSeq[Int] = Vector(0, 3, 6)

注意:我使用withFilter而不是filter来避免创建临时集合。

或者您可以使用collect,它会对定义它的元素应用部分函数:

scala> s.zipWithIndex.collect { case (char, index) if char == '1' => index }
res2: scala.collection.immutable.IndexedSeq[Int] = Vector(0, 3, 6)