Scala—Sliding(滑动窗口)用法详解
Scala 的 sliding
方法在处理集合时,可以方便地获取一个集合的“滑动窗口”(能够按照指定的窗口大小和步长从集合中获取子集合)。
sliding
方法定义:
def sliding(size: Int, step: Int = 1): Iterator[Seq[A]]
-
size
:窗口的大小,即每次从集合中取出的元素个数。 -
step
(可选):滑动的步长,默认是1
,即窗口每次移动一个元素。如果设置为大于 1 的值,窗口会跳过指定数量的元素。 -
sliding
方法返回一个Iterator[Seq[A]]
,即一个迭代器,每次迭代都会返回一个大小为size
的子集合。
Demo🤣🤣🤣:
生成一个大小为 3 的滑动窗口:
val list = List(1, 2, 3, 4, 5)
val slidingWindow = list.sliding(3)slidingWindow.foreach(println)
Demo🤣🤣🤣:
步长设置为 2
,窗口每次就会滑动两个位置:
val list = List(1, 2, 3, 4, 5)
val slidingWindow = list.sliding(3, 2)slidingWindow.foreach(println)
Demo🤣🤣🤣:
集合的剩余元素不足一个完整的窗口,仍然会返回一个子集合,包含剩余的元素。
val list = List(1, 2, 3, 4, 5)
val slidingWindow = list.sliding(6)slidingWindow.foreach(println)
List(1, 2, 3, 4, 5)
Demo🤣🤣🤣:
从字符串中提取所有长度为 4 的子字符串:
val str = "abcdefgh"
val slidingWindow = str.sliding(4)slidingWindow.foreach(println)