3

我在播放框架的 scala 模板中有一个字符串列表。
我想一次迭代列表的一半,然后第二次迭代列表的另一半。
我不确定如何为此编写有效的迭代器。

我已经尝试过
@for(i <- 0 until list.length/2 ) {list(i) }
,然后是第二个循环

@for(i <- list.length/2+1 until list.length ) 
 { list(i) } 


这可行,但复杂性变得很高。

后来我做了

  @defining(list.size) { size => 
    @for(i <- 0 until size/2) 
    {list(i) }
  }


现在它似乎工作正常。

4

3 回答 3

5

这是一种方法。

scala> List("a","b","c","d","e")
res0: List[String] = List(a, b, c, d, e)

scala> res0.splitAt(res0.size/2)
res1: (List[String], List[String]) = (List(a, b),List(c, d, e))

scala> res1._1.foreach(println(_))
a
b

scala> res1._2.foreach(println(_))
c
d
e
于 2013-08-19T06:01:36.223 回答
1

使用滑动创建迭代器,

scala> val input = List(1, 2, 3)
input: List[Int] = List(1, 2, 3)

scala> val step = (input.length + 1 ) / 2
step: Int = 2

scala> val sliding = input.sliding(step, step)
sliding: Iterator[List[Int]] = non-empty iterator

scala> val left = sliding.next()
left: List[Int] = List(1, 2)

scala> val right = sliding.next()
right: List[Int] = List(3)

scala> left.foreach(println)
1
2

scala> right.foreach(println)
3

或使用 take & drop,

scala> val input = List(1, 2, 3)
input: List[Int] = List(1, 2, 3)

scala> val step = (input.length + 1 ) / 2
step: Int = 2

scala> input.take(step).foreach(println)
1
2

scala> input.drop(step).foreach(println)
3
于 2013-08-19T08:48:42.677 回答
0

Iterator可能是一个不错的选择。

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

scala> val iterator = list.toIterator
iterator: Iterator[Int] = non-empty iterator

scala> val half = (0 until list.size / 2)
half: scala.collection.immutable.Range = Range(0, 1, 2)

scala> val left = (list.size / 2 until list.size)
left: scala.collection.immutable.Range = Range(3, 4, 5)

scala> half foreach { x => println(x + ":" + iterator.next) }
0:1
1:2
2:3

scala> left foreach { x => println(x + ":" + iterator.next) }
3:4
4:5
5:6
于 2013-08-19T08:47:27.787 回答