Scala - 集合(Set)



Scala Set 是一個包含相同型別且彼此不同的元素的集合。換句話說,Set 是一個不包含重複元素的集合。Set 有兩種型別:**不可變** 和 **可變**。不可變物件和可變物件的區別在於,不可變物件本身不能被修改。

預設情況下,Scala 使用不可變 Set。如果要使用可變 Set,則必須顯式匯入 `scala.collection.mutable.Set` 類。如果要在同一個集合中同時使用可變和不可變 Set,則可以繼續將不可變 Set 稱為 `Set`,而可變 Set 稱為 `mutable.Set`。

以下是宣告不可變 Set 的方法:

語法

// Empty set of integer type
var s : Set[Int] = Set()

// Set of integer type
var s : Set[Int] = Set(1,3,5,7)

or 

var s = Set(1,3,5,7)

定義空 Set 時,型別註解是必要的,因為系統需要為變數分配具體的型別。

Set 的基本操作

Set 的所有操作都可以用以下三種方法表示:

序號 方法及描述
1

head

此方法返回 Set 的第一個元素。

2

tail

此方法返回包含除第一個元素之外所有元素的 Set。

3

isEmpty

如果 Set 為空,則此方法返回 true,否則返回 false。

嘗試以下示例,該示例演示了基本操作方法的用法:

示例

object Demo {
   def main(args: Array[String]) {
      val fruit = Set("apples", "oranges", "pears")
      val nums: Set[Int] = Set()

      println( "Head of fruit : " + fruit.head )
      println( "Tail of fruit : " + fruit.tail )
      println( "Check if fruit is empty : " + fruit.isEmpty )
      println( "Check if nums is empty : " + nums.isEmpty )
   }
}

將上述程式儲存為 `Demo.scala`。可以使用以下命令編譯和執行此程式。

命令

\>scalac Demo.scala
\>scala Demo

輸出

Head of fruit : apples
Tail of fruit : Set(oranges, pears)
Check if fruit is empty : false
Check if nums is empty : true

連線 Set

可以使用 `++` 運算子或 `Set.++()` 方法連線兩個或多個 Set,但在新增 Set 時會刪除重複元素。

以下是連線兩個 Set 的示例。

示例

object Demo {
   def main(args: Array[String]) {
      val fruit1 = Set("apples", "oranges", "pears")
      val fruit2 = Set("mangoes", "banana")

      // use two or more sets with ++ as operator
      var fruit = fruit1 ++ fruit2
      println( "fruit1 ++ fruit2 : " + fruit )

      // use two sets with ++ as method
      fruit = fruit1.++(fruit2)
      println( "fruit1.++(fruit2) : " + fruit )
   }
}

將上述程式儲存為 `Demo.scala`。可以使用以下命令編譯和執行此程式。

命令

\>scalac Demo.scala
\>scala Demo

輸出

fruit1 ++ fruit2 : Set(banana, apples, mangoes, pears, oranges)
fruit1.++(fruit2) : Set(banana, apples, mangoes, pears, oranges)

查詢 Set 中的最大、最小元素

可以使用 `Set.min` 方法查詢 Set 中的最小元素,使用 `Set.max` 方法查詢 Set 中的最大元素。以下示例演示了該程式。

示例

object Demo {
   def main(args: Array[String]) {
      val num = Set(5,6,9,20,30,45)

      // find min and max of the elements
      println( "Min element in Set(5,6,9,20,30,45) : " + num.min )
      println( "Max element in Set(5,6,9,20,30,45) : " + num.max )
   }
}

將上述程式儲存為 `Demo.scala`。可以使用以下命令編譯和執行此程式。

命令

\>scalac Demo.scala
\>scala Demo

輸出

Min element in Set(5,6,9,20,30,45) : 5
Max element in Set(5,6,9,20,30,45) : 45

查詢 Set 中的公共值

可以使用 `Set.&` 方法或 `Set.intersect` 方法查詢兩個 Set 之間的公共值。嘗試以下示例以顯示用法。

示例

object Demo {
   def main(args: Array[String]) {
      val num1 = Set(5,6,9,20,30,45)
      val num2 = Set(50,60,9,20,35,55)

      // find common elements between two sets
      println( "num1.&(num2) : " + num1.&(num2) )
      println( "num1.intersect(num2) : " + num1.intersect(num2) )
   }
}

將上述程式儲存為 `Demo.scala`。可以使用以下命令編譯和執行此程式。

命令

\>scalac Demo.scala
\>scala Demo

輸出

num1.&(num2) : Set(20, 9)
num1.intersect(num2) : Set(20, 9)

Scala Set 方法

以下是使用 Set 時可以使用的一些重要方法。有關可用方法的完整列表,請檢視 Scala 的官方文件。

序號 方法及描述
1

def +(elem: A): Set[A]

建立一個新的 Set,其中包含一個附加元素(除非該元素已存在)。

2

def -(elem: A): Set[A]

建立一個新的 Set,其中從當前 Set 中刪除了給定元素。

3

def contains(elem: A): Boolean

如果 elem 包含在此 Set 中,則返回 true,否則返回 false。

4

def &(that: Set[A]): Set[A]

返回一個新的 Set,其中包含同時存在於此 Set 和給定 Set 中的所有元素。

5

def &~(that: Set[A]): Set[A]

返回此 Set 與另一個 Set 的差集。

6

def +(elem1: A, elem2: A, elems: A*): Set[A]

建立一個新的不可變 Set,其中包含來自傳遞的 Set 的附加元素

7

def ++(elems: A): Set[A]

將此不可變 Set 與另一個集合的元素連線到此不可變 Set。

8

def -(elem1: A, elem2: A, elems: A*): Set[A]

返回一個新的不可變 Set,其中包含當前不可變 Set 的所有元素,但給定引數元素的每個元素都少一個。

9

def addString(b: StringBuilder): StringBuilder

將此不可變 Set 的所有元素追加到 StringBuilder。

10

def addString(b: StringBuilder, sep: String): StringBuilder

使用分隔符字串將此不可變 Set 的所有元素追加到 StringBuilder。

11

def apply(elem: A)

測試此 Set 中是否包含某些元素。

12

def count(p: (A) => Boolean): Int

計算滿足謂詞的不可變 Set 中的元素個數。

13

def copyToArray(xs: Array[A], start: Int, len: Int): Unit

將此不可變 Set 的元素複製到陣列。

14

def diff(that: Set[A]): Set[A]

計算此 Set 與另一個 Set 的差集。

15

def drop(n: Int): Set[A]

返回除前 n 個元素之外的所有元素。

16

def dropRight(n: Int): Set[A]

返回除最後 n 個元素之外的所有元素。

17

def dropWhile(p: (A) => Boolean): Set[A]

刪除滿足謂詞的最長字首元素。

18

def equals(that: Any): Boolean

任意序列的 equals 方法。將此序列與其他物件進行比較。

19

def exists(p: (A) => Boolean): Boolean

測試謂詞是否適用於此不可變 Set 的某些元素。

20

def filter(p: (A) => Boolean): Set[A]

返回滿足謂詞的此不可變 Set 的所有元素。

21

def find(p: (A) => Boolean): Option[A]

查詢滿足謂詞的不可變 Set 的第一個元素(如果有)。

22

def forall(p: (A) => Boolean): Boolean

測試謂詞是否適用於此不可變 Set 的所有元素。

23

def foreach(f: (A) => Unit): Unit

將函式 f 應用於此不可變 Set 的所有元素。

24

def head: A

返回此不可變 Set 的第一個元素。

25

def init: Set[A]

返回除最後一個元素之外的所有元素。

26

def intersect(that: Set[A]): Set[A]

計算此 Set 與另一個 Set 之間的交集。

27

def isEmpty: Boolean

測試此 Set 是否為空。

28

def iterator: Iterator[A]

為可迭代物件中包含的所有元素建立一個新的迭代器。

29

def last: A

返回最後一個元素。

30

def map[B](f: (A) => B): immutable.Set[B]

透過將函式應用於此不可變 Set 的所有元素來構建新的集合。

31

def max: A

查詢最大的元素。

32

def min: A

查詢最小的元素。

33

def mkString: String

以字串形式顯示此不可變 Set 的所有元素。

34

def mkString(sep: String): String

使用分隔符字串以字串形式顯示此不可變 Set 的所有元素。

35

def product: A

返回此不可變 Set 的所有元素關於 num 中的 * 運算子的乘積。

36

def size: Int

返回此不可變 Set 中的元素個數。

37

def splitAt(n: Int): (Set[A], Set[A])

返回一對不可變 Set,包含此不可變 Set 的前 n 個元素和其他元素。

38

def subsetOf(that: Set[A]): Boolean

如果此 Set 是 that 的子集(即,如果此 Set 的每個元素也是 that 的元素),則返回 true。

39

def sum: A

返回此不可變 Set 的所有元素關於 num 中的 + 運算子的和。

40

def tail: Set[A]

返回一個不可變 Set,其中包含此不可變 Set 的所有元素,但第一個元素除外。

41

def take(n: Int): Set[A]

返回前 n 個元素。

42

def takeRight(n: Int):Set[A]

返回最後 n 個元素。

43

def toArray: Array[A]

返回一個包含此不可變 Set 的所有元素的陣列。

44

def toBuffer[B >: A]: Buffer[B]

返回一個包含此不可變 Set 的所有元素的緩衝區。

45

def toList: List[A]

返回一個包含此不可變 Set 的所有元素的列表。

46

def toMap[T, U]: Map[T, U]

將此不可變 Set 轉換為 Map。

47

def toSeq: Seq[A]

返回一個包含此不可變 Set 的所有元素的 seq。

48

def toString(): String

返回物件的字串表示形式。

scala_collections.htm
廣告