1.编写一段代码,将a设置为一个n个随机整数的数组,要求随机数介于0(包含)和n(不包含)之间。
val n = 100 //n是自己给定的
val a = scala.util.Random
val b = new Array[Int](n) // new Array 和 Array 是有区别的
for(i <- 0 until b.length){
b(i) = a.nextInt(n)
}
println(b.mkString(" and "))
2.编写一个循环,将整数数组中相邻的元素置换。
例如,Array(1,2,3,4,5)
置换后变为Array(2,1,4,3,5)
var a = Array(1,2,3,4,5)
for(i <- 0 until (a.length,2) if i < a.length -1){
val tmp = a(i)
a(i) = a(i+1)
a(i+1) = tmp
}
println(a.mkStirng(" and "))
3.重复前一个练习,不过这一次生成一个新的值交换过的数组。用for/yield。
val a = Array(1,2,3,4,5)
val b = (for(i <- 0 until (a.length,2))
yield
if(i < a.length -1 ) Array(a(i+1),a(i))
else Array(a(i))).flatten.toArray()
println(b.mkString(" and "))
4.给定一个整数数组,产出一个新的数组,包含元素组中的所有正值,以原有顺序排列,之后的元素是所有零或负值,以原有顺序排序。
val a = Array(1,-1,-3,0,4,-2,4,87,0,-10,9)
val b = ArrayBuffer[Int]()
val c = ArrayBuffer[Int]()
a.foreach(arg => if(arg>0) b += arg else c+=arg)
b++=c
println(b.mkString(" and ")
5.如何计算Array[Double]的平均值
val h = Array(0.1,46.3,24.0,234.2,-4.2)
val hMean = h.sum/h.length
6.如何重新组织Array[Int]的元素将它们以反序排列?对于ArrayBuffer[Int]你又会怎么做呢?
//以上一题的Array[Double]为例
val h = Array(0.1,46.3,24.0,234.2,-4.2)
for(i <- 0 until h.length/2 ){
val tmp = h(i)
h(i) = h(h.length-1-i)
h(h.length-1-i) = tmp
}
println(h.mkString(" "))
//ArrayBuffer
val h = Array(0.1,46.3,24.0,234.2,-4.2)
val hReverse = h.reverse
7.编写代码,去掉数组中的所有值,去掉重复项。(查看Scaladoc)
val g = Array(1,-1,-3,0,4,-2,4,87,0,-10,9)
println(g.distinct.mkString(" ")
8.重新编写3.4节结尾的示例。收集负值元素的下标,反序,去掉最后一个下标,然后对每个下标调用a.remove(i).比较这样做的效率和3.4节中另外两种方法的效率。
略
9.创建一个由java.util.TimeZone.getAvailableIDs返回的时区集合,判断条件是它们在美洲。去掉”America/”前缀并排序。
val timeZone = java.util.TimeZone.getAvailableIDs
val americaTimeZone = timeZone.filter(_.take(8)=="America/")
val sortedAmericaTimeZone = americaTimeZone.map(_.drop(8)).sorted
10.引入java.awt.datatransfer._并构建一个类型为SystemFlavorMap类型的对象
val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap]
然后以DataFlavor.imageFlavor
为参数调用getNativesForFlavor
方法,以Scala缓冲保存返回值。(为什么用这样一个晦涩难懂的类?因为在Java标准中很难找得到使用java.util.List
的代码。)
import java.awt.datatransfer._
val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap]
flavors.getNativesForFlavor(DataFlavor.imageFlavor).toArray.toBuffer
println(xx.mkString(" "))