
- Scala 教程
- Scala - 首頁
- Scala - 概述
- Scala - 特性
- Scala - 環境搭建
- Scala - 構建工具 (SBT)
- Scala - 基本語法
- 資料型別和變數
- Scala - 資料型別
- Scala - 變數
- Scala - 字串
- Scala - 陣列
- Scala 運算子
- Scala - 運算子
- Scala - 算術運算子
- Scala - 關係運算符
- Scala - 邏輯運算子
- Scala - 位運算子
- Scala - 賦值運算子
- Scala 條件語句
- Scala - if else
- Scala 迴圈語句
- Scala - 迴圈語句
- Scala - while 迴圈
- Scala - do-while 迴圈
- Scala - for 迴圈
- Scala - break 語句
- Scala 類與物件
- Scala - 類與物件
- Scala - 訪問修飾符
- Scala 方法與函式
- Scala - 函式
- Scala - 按名稱呼叫函式 (Call-by-Name)
- Scala - 帶有名引數的函式
- Scala - 帶有可變引數的函式
- Scala - 遞迴函式
- Scala - 預設引數值
- Scala - 高階函式
- Scala - 巢狀函式
- Scala - 匿名函式
- 部分應用函式
- Scala - Currying 函式
- Scala 集合
- Scala - 集合
- Scala - 列表 (List)
- Scala - 集合(Set)
- Scala - 對映 (Map)
- Scala - 元組 (Tuple)
- Scala - 迭代器 (Iterator)
- Scala - Option
- Scala 模式匹配
- Scala - 模式匹配
- Scala - 異常處理
- Scala - 提取器 (Extractor)
- Scala - 正則表示式
- Scala 檔案 I/O
- Scala - 檔案 I/O
- Scala 高階概念
- Scala - 閉包 (Closure)
- Scala - 特質 (Trait)
- Scala 有用資源
- Scala - 快速指南
- Scala - 線上編譯器
- Scala - 有用資源
- Scala - 討論
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 返回物件的字串表示形式。 |