scala 學習之: list.fill 用法


題目描述:

Decode a run-length encoded list.
Given a run-length code list generated as specified in problem P10, construct its uncompressed version.
Example:

scala> decode(List((4, 'a), (1, 'b), (2, 'c), (2, 'a), (1, 'd), (4, 'e)))
res0: List[Symbol] = List('a, 'a, 'a, 'a, 'b, 'c, 'c, 'a, 'a, 'd, 'e, 'e, 'e, 'e)

根據List中的元素,將其展開, 與之前的encodeList 做相反的操作。 

思路: 使用之前提到的foldLeft函數, 從左到右遍歷List,將其每一個元組展開,放入初始值里面。

代碼:

   def decodeList[T](a:List[(Int, T)]): List[T] = a.foldLeft(List[T]()){
      case (res, cur) => {
           val count = cur._1
           val content = cur._2
           res:::List.fill(count)(content)
       }
      }
    val b = List((10, "a"), (2,"zb"))
    println(decodeList(b))

List.fill:

  def fill[A](n: Int)(elem: => A): CC[A] = {
    val b = newBuilder[A]
    b.sizeHint(n)
    var i = 0
    while (i < n) {
      b += elem
      i += 1
    }
    b.result
  }

向集合中插入n個類型為A的元素。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM