• 快学Scala习题解答—第三章 数组相关操作


    3 数组相关操作 
    3.1 编写一段代码。将a设置为一个n个随机整数的数组,要求随机数介于0(包括)和n(不包括)之间 
    random和yield的使用 
    Scala代码  收藏代码
    1. import scala.math.random  
    2.   
    3. def randomArray(n:Int)={  
    4.   for(i <- 0 until n) yield (random * n).toInt  
    5. }  
    6.   
    7. println(randomArray(10).mkString(","))  


    3.2 编写一个循环,将整数数组中相邻的元素置换。比如,Array(1,2,3,4,5)经过置换后变为Array(2,1,4,3,5) 
    对数组方法的使用 
    Scala代码  收藏代码
    1. def reorderArray(arr:Array[Int]):Array[Int]={  
    2.   val t = arr.toBuffer  
    3.   for(i <- 1 until (t.length,2);tmp = t(i);j <- i - 1 until i){  
    4.     t(i) = t(j)  
    5.     t(j) = tmp  
    6.   }  
    7.   t.toArray  
    8. }  
    9.   
    10. println(reorderArray(Array(1,2,3,4,5)).mkString(","))  


    3.3 反复前一个练习,只是这一次生成一个新的值交换过的数组。用for/yield 
    Scala代码  收藏代码
    1. def reorderArray(arr:Array[Int]):Array[Int]={  
    2.   (for(i <- 0 until (arr.length,2)) yield if (i + 1 < arr.length) Array(arr(i + 1),arr(i)) else Array(arr(i))).flatten.toArray  
    3. }  
    4.   
    5. println(reorderArray(Array(1,2,3,4,5)).mkString(","))  


    3.4 给定一个整数数组,产生一个新的数组,包括元数组中的全部正值,以原有顺序排列,之后的元素是全部零或负值。以原有顺序排列
     
    Scala代码  收藏代码
    1. //使用循环  
    2.  def reorderArray(arr:Array[Int]):Array[Int]={  
    3.      val a = ArrayBuffer[Int]()  
    4.      val b = ArrayBuffer[Int]()  
    5.      arr.foreach(arg => if(arg > 0) a += arg else b += arg)  
    6.      a ++= b  
    7.      a.toArray  
    8.  }  
        val a = Array(1,3,-3,-5,-7,3,2)
        def reorderArray(arr: Array[Int]) = {
          val  b = arr.filter(_ > 0)
          val  c = arr.filter(_ <= 0)
          val newarr = b ++ c
          print(newarr.toBuffer.toString())
        }
          reorderArray(a)


    3.5 怎样计算Array[Double]的平均值? 
    Scala代码  收藏代码
    1. def aveArray(arr:Array[Double]):Double={  
    2.   arr.sum/arr.length  
    3. }  


    3.6 怎样又一次组织Array[Int]的元素将他们以反序排列?对于ArrayBuffer[Int]你又会怎么做呢? 
    Scala代码  收藏代码
    1. def reverseArray(arr:Array[Int]):Array[Int]={  
    2.   arr.reverse  
    3. }  


    3.7 编写一段代码,产出数组中的全部值。去掉反复项。

    (提示:查看Scaladoc) 
    产出数组的代码就不编写了。去重仅仅须要调用api就可以 

    Scala代码  收藏代码
    1. def distinctArray(arr:Array[Int]):Array[Int]={  
    2.   val t = arr.toBuffer  
    3.   t.distinct.toArray  
    4. }  


    3.8 又一次编写3.4节结尾的演示样例。收集负值元素的下标。反序,去掉最后一个下标。然后对每一个下标调用a.remove(i)。

    比較这样做的效率和3.4节中另外两种方法的效率

       def removeArray(array: Array[Int]){
          val t = array.toBuffer
          val index = for (i <- 0 until array.length if array(i) < 0) yield i
          val right = index.reverse.dropRight(1)
          right.foreach(t.remove(_))
          print(t)
        }
        
        val a = Array(1,3,-3,-5,-7,3,2,1)
        removeArray(a)


    3.9 创建一个由java.util.TimeZone.getAvailableIDs返回ide时区集合,推断条件是它们在美洲。去掉"America/"前缀并排序 

     val americaTimeZone = java.util.TimeZone.getAvailableIDs
    val americatimezone = java.util.TimeZone.getAvailableIDs.filter(_.take(8)=="America/")
    val sortedamericaTimeZone = americaTimeZone.map(_.drop(8)).sorted


    3.10 引入java.awt.datatransfer.并构建一个类型为SystemFlavorMap类型的对象: 

    val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap] 然后以DataFlavor.imageFlavor为參数调用getNativesForFlavor方法。以Scala缓冲保存返回值。 (为什么用这样一个晦涩难懂的类?由于在Java标准库中非常难找到使用java.util.List的代码) 
    Scala代码  收藏代码
    1. val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap]  
    2. println(flavors.getNativesForFlavor(DataFlavor.imageFlavor).toArray.toBuffer.mkString(" | ")  
  • 相关阅读:
    大学生程序猿IT情书“2014爱的告白挑战赛”获奖名单及优秀情书展示系列之
    Codeforces 385C Bear and Prime Numbers
    CSU1659: Graph Center(最短路)
    新版ADT出现appcompat_v7的问题
    @IBDesignable和@IBInspectable
    FTP命令详解
    R语言屏幕输出
    R语言常用基础知识(入门)
    R语言数据类型转换
    使用建议(内部使用)
  • 原文地址:https://www.cnblogs.com/jhcelue/p/7069613.html
Copyright © 2020-2023  润新知