Scala陣列


Scala提供了一種資料結構叫作陣列,陣列是一種儲存了相同型別元素的固定大小順序集合。陣列用於儲存資料集合,但將陣列視為相同型別變數的集合通常更為有用。

可以宣告一個陣列變數,例如:numbers,使用numbers[0]numbers[1]...numbers[99]來表示單個變數,而不是分別地宣告每個變數,例如number0number1...等變數。 本教學介紹如何使用索引變數宣告陣列變數,建立陣列和使用陣列。陣列的第一個元素的索引是數位0,最後一個元素的索引是元素的總數減去1

宣告陣列變數

要在程式中使用陣列,必須先宣告一個變數來參照陣列,並且必須指定變數可參照的陣列型別。

以下是宣告陣列變數的語法。

語法

var z:Array[String] = new Array[String](3)

// 或者

var z = new Array[String](3)

這裡,變數z被宣告為可以容納三個元素的字串陣列。可以將值分配給單個元素或存取每個元素,存取元素通過使用如下命令來完成:

z(0) = "Zara"; z(1) = "Nuha"; z(4/2) = "Ayan"

一般來說,索引可以是產生整數的任何表示式。還有一種定義陣列的方法 -

var z = Array("Maxsu", "Nancy", "Alen")

以下圖片表示一個名稱為:myList的陣列。 這裡,myList儲存十個雙精度(double)值,索引為09

處理處理

當處理陣列元素時,我們經常使用迴圈控制結構,因為陣列中的所有元素都是相同的型別,陣列的大小是已知的。

下面是一個範例程式,演示如何建立,初始化和處理陣列 -

範例

object Demo {
   def main(args: Array[String]) {
      var myList = Array(1.9, 2.9, 3.4, 3.5)

      // Print all the array elements
      for ( x <- myList ) {
         println( x )
      }

      // Summing all elements
      var total = 0.0;

      for ( i <- 0 to (myList.length - 1)) {
         total += myList(i);
      }
      println("Total is " + total);

      // Finding the largest element
      var max = myList(0);

      for ( i <- 1 to (myList.length - 1) ) {
         if (myList(i) > max) max = myList(i);
      }

      println("Max is " + max);
   }
}

將上述程式儲存在原始檔:Demo.scala中,使用以下命令編譯和執行此程式。

D:\>scalac Demo.scala
D:\>scala Demo

1.9
2.9
3.4
3.5
Total is 11.7
Max is 3.5

Scala不直接支援各種陣列操作,它提供各種方法來處理任何維度的陣列。 如果要使用不同的方法,則需要匯入Array._包。

多維陣列

在許多情況下,需要定義和使用多維陣列(即陣列的陣列)。 例如,矩陣和表是可以被實現為二維陣列結構的例子。

以下是定義二維陣列的範例 -

var myMatrix = ofDim[Int](3,3)

這是一個具有三個元素的陣列,每個元素都是一個具有三個元素的整數陣列。

嘗試以下範例程式來處理多維陣列 -

import Array._

object Demo {
   def main(args: Array[String]) {
      var myMatrix = ofDim[Int](3,3)

      // build a matrix
      for (i <- 0 to 2) {
         for ( j <- 0 to 2) {
            myMatrix(i)(j) = j;
         }
      }

      // Print two dimensional array
      for (i <- 0 to 2) {
         for ( j <- 0 to 2) {
            print(" " + myMatrix(i)(j));
         }
         println();
      }
   }
}

將上述程式儲存在原始檔:Demo.scala中,使用以下命令編譯和執行此程式。

D:\>scalac Demo.scala
D:\>scala Demo

0 1 2
0 1 2
0 1 2

連線陣列

嘗試使用concat()方法連線兩個陣列的以下範例。可以將多個陣列作為引數傳遞給concat()方法。

import Array._

object Demo {
   def main(args: Array[String]) {
      var myList1 = Array(1.9, 2.9, 3.4, 3.5)
      var myList2 = Array(8.9, 7.9, 0.4, 1.5)

      var myList3 =  concat( myList1, myList2)

      // Print all the array elements
      for ( x <- myList3 ) {
         println( x )
      }
   }
}

將上述程式儲存在原始檔:Demo.scala中,使用以下命令編譯和執行此程式。

D:\>scalac Demo.scala
D:\>scala Demo

1.9
2.9
3.4
3.5
8.9
7.9
0.4
1.5

使用範圍建立陣列

使用range()方法來生成包含給定範圍內增加整數序列的陣列。 您可以使用final引數作為步差來建立序列; 如果不使用final引數,則步差將被假定為1

讓我們舉個例子來建立一個範圍(10,20,2)的陣列:建立一個陣列,其元素介於1020之間,範圍步差為2,陣列中的元素是:10,12,14,1618

另一個例子:range(10,20)。 這裡的範圍不同,預設情況下它假定為1個元素。 它建立一個陣列,其元素介於1020之間,範圍步差為1。陣列中的元素為:10,11,12,13...19

以下範例程式顯示如何使用範圍建立陣列。

範例

import Array._

object Demo {
   def main(args: Array[String]) {
      var myList1 = range(10, 20, 2)
      var myList2 = range(10,20)

      // Print all the array elements
      for ( x <- myList1 ) {
         print( " " + x )
      }

      println()
      for ( x <- myList2 ) {
         print( " " + x )
      }
   }
}

將上述程式儲存在原始檔:Demo.scala中,使用以下命令編譯和執行此程式。

D:\>scalac Demo.scala
D:\>scala Demo

10 12 14 16 18
10 11 12 13 14 15 16 17 18 19

Scala陣列方法

以下是使用陣列時可以使用的重要方法。 如上所示,必須在使用任何上述方法之前匯入Array._包。 有關可用方法的完整列表,請檢視Scala的官方文件。

序號 方法 說明
1 def apply( x: T, xs: T* ): Array[T] 建立一個T物件陣列,其中T可以是:UnitDoubleFloatLongIntCharShortByteBoolean
2 def concat[T]( xss: Array[T]* ): Array[T] 將所有陣列連線成一個陣列。
3 def copy( src: AnyRef, srcPos: Int, dest: AnyRef, destPos: Int, length: Int ): Unit 將一個陣列複製到另一個。 相當於Java的System.arraycopy(src,srcPos,dest,destPos,length)
4 def empty[T]: Array[T] 返回長度為0的陣列
5 def iterate[T]( start: T, len: Int )( f: (T) => T ): Array[T] 返回一個包含函式的重複應用程式到一個起始值的陣列。
6 def fill[T]( n: Int )(elem: => T): Array[T] 返回一個包含某些元素計算結果的陣列。
7 def fill[T]( n1: Int, n2: Int )( elem: => T ): Array[Array[T]] 返回一個包含一些元素計算結果的二維陣列。
8 def iterate[T]( start: T, len: Int)( f: (T) => T ): Array[T] 返回一個包含一個函式的重複應用程式到一個起始值的陣列。
9 def ofDim[T]( n1: Int ): Array[T] 建立具有給定維度的陣列。
10 def ofDim[T]( n1: Int, n2: Int ): Array[Array[T]] 建立一個二維陣列
11 def ofDim[T]( n1: Int, n2: Int, n3: Int ): Array[Array[Array[T]]] 建立一個3維陣列
12 def range( start: Int, end: Int, step: Int ): Array[Int] 返回一個整數間隔中包含相等間隔值的陣列。
13 def range( start: Int, end: Int ): Array[Int] 返回一個包含一個範圍內增加整數序列的陣列。
14 def tabulate[T]( n: Int )(f: (Int)=> T): Array[T] 0開始的整數值範圍內,返回一個包含給定函式值的陣列。
15 def tabulate[T]( n1: Int, n2: Int )( f: (Int, Int ) => T): Array[Array[T]] 返回一個二維陣列,其中包含從0開始的整數值範圍內給定函式的值。