scala – 在数组中查找索引的功能代码

我想在功能样式中重构这段 Scala代码

var k = -1
for (i <- 0 until array.length)
  if ((i < array.length - 1) && array(i) < array(i + 1))
    k = i

Scala中的数组有indexWhere,可用于val index = array.indexWhere(c => c ==’a’).我正在寻找类似的东西,它将考虑数组的两个连续元素.

解决方法

当你需要查看集合中的相邻元素时,通常的功能方法是用它的尾部“压缩”集合.请考虑以下简化示例:

scala> val xs = List(5,4,2,3,1)
xs: List[Int] = List(5,1)

scala> val tail = xs.tail
tail: List[Int] = List(4,1)

scala> xs.zip(tail)
res0: List[(Int,Int)] = List((5,4),(4,2),(2,3),(3,1)

现在我们可以使用indexWhere:

scala> res0.indexWhere { case (x,y) => x < y }
res1: Int = 2

在您的情况下,以下内容基本上等同于您的代码

val k = (array zip array.tail) lastIndexWhere { case (x,y) => x < y }

我正在使用lastIndexWhere而不是indexWhere,因为在你的代码中,当你遇到一个谓词所在的对时,你不会停止循环.

相关文章

共收录Twitter的14款开源软件,第1页Twitter的Emoji表情 Tw...
Java和Scala中关于==的区别Java:==比较两个变量本身的值,即...
本篇内容主要讲解“Scala怎么使用”,感兴趣的朋友不妨来看看...
这篇文章主要介绍“Scala是一种什么语言”,在日常操作中,相...
这篇文章主要介绍“Scala Trait怎么使用”,在日常操作中,相...
这篇文章主要介绍“Scala类型检查与模式匹配怎么使用”,在日...