1. 編寫一段代碼,將a設置爲一個n個隨機整數的數組,要求隨機數介於0(包含)和n(不包含)之間。java
val a=ArrayBuffer() ++ (0 until 10)
2. 編寫一個循環,將整數數組中相鄰的元素置換。例如,Array(1,2,3,4,5)通過置換後變爲Array(2,1,4,3,5)數組
def homeWork2(arr:Array[Int])={ for(i<- 0 until (arr.length,2) if i<arr.length-1 ){ val a = arr(i) arr(i)=arr(i+1) arr(i+1) = a } println(arr.mkString(",")) }
3. 重複前一個練習,不過此次生成一個新的值交換過的數組。用for/yield。ui
def homeWork3(arr:Array[Int])={ var resultArry=for(i<- 0 until arr.length) yield { if(i%2==0) if(i==(arr.length-1)) arr(i) else arr(i+1) else arr(i-1) } println(resultArry.mkString(",")) }
4. 給定一個整數數組,產出一個新的數組,包含元數組中的全部正值,以原有順序排列,以後的元素是全部零或負值,以原有順序排列。scala
def homeWork4(arr:Array[Int])={ val resultArr=arr.filter { _>0 } ++ arr.filter { _<=0 } println(resultArr.mkString(",")) }
5. 如何計算Array[Double]的平均值?code
def homeWork5(arr:Array[Double])={ println (arr.sum/arr.length) }
6. 如何從新組織Array[Int]的元素將它們反序排列?對於ArrayBuffer[Int]你又會怎麼作呢?對象
def homeWork6(arrInt:Array[Int],arrBuf:ArrayBuffer[Int])={ val a=for(i<- 0 until arrInt.length reverse) yield { arrInt(i)} println("array:"+a.mkString(",")) val b=new ArrayBuffer[Int]() b++=arrBuf.reverse println("arrayBuffer:"+b.mkString(",")) }
7. 編寫一段代碼,產出數組中的全部值,去掉重複項。排序
def homeWork7()={ val a=Array(1,2,5,4,5,6,4,3) val b=a.distinct println("array:"+b.mkString(",")) }
8. 從新編寫3.4節結尾的示例。收集負值元素的下標,反序,去掉最後一個下標,而後對每個下標調用a.remove(i)。比較這樣作的效率和3.4節中另外兩種方法的效率。rem
//數組緩衝的尾端添加或移除元素是高效的,在任意位置插入或者移除元素,不是高效的,由於全部在那個位置以後的元素都必須被平移 def homeWork8()={ val a=ArrayBuffer(0,-1,2,5,-7,-3,7,9) val indexes=for(i <-0 until a.length if a(i)<0) yield i val tmp=indexes.reverse.dropRight(1) for(i<-tmp) a.remove(i) println("arrayBuffer:"+a.mkString(",")) }
9. 建立一個由java.util.TimeZone.getAvailableIDs返回的時區集合,判斷條件是它們在美洲,去掉」America/「前綴並排序。get
def homeWork9()={ val a=java.util.TimeZone.getAvailableIDs() val tmp=for(arr<-a) yield { if(arr.startsWith("America") ) arr.replaceFirst("America/", "") else arr } scala.util.Sorting.quickSort(tmp) println(tmp.mkString(",")) }
10. 引入java.awt.datatransfer._並構建一個類型爲SystemFlavorMap類型的對象,而後以DataFlavor.imageFlavor爲參數調用getNativesForFlavor方法,以Scala緩衝保存返回值。it
def homeWork10()={ val buffer=new ArrayBuffer[String]() val tmp = SystemFlavorMap.getDefaultFlavorMap.getNativesForFlavors(Array(DataFlavor.imageFlavor)) val iter=tmp.values().iterator() while(iter.hasNext()) buffer+=iter.next() println(buffer.mkString(",")) }