Scala - 集合

Scala Set 是相同类型的成对不同元素的集合。 换句话说,Set 是一个不包含重复元素的集合。 Set 有两种,immutablemutable。 可变对象和不可变对象的区别在于,当一个对象不可变时,对象本身是不能改变的。

默认情况下,Scala 使用不可变的 Set。 如果要使用可变 Set,则必须显式导入 scala.collection.mutable.Set 类。 如果你想在同一个集合中同时使用可变集合和不可变集合,那么你可以继续将不可变集合称为 Set 但你可以将可变集合称为 mutable.Set< /b>。

这是声明不可变集的方法 −

语法

// 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)

在定义一个空集时,类型注释是必要的,因为系统需要为变量分配一个具体的类型。


集合基本操作

集合上的所有操作都可以用以下三种方法表示 −

序号 方法 & 描述
1

head

此方法返回集合的第一个元素。

2

tail

此方法返回一个由除第一个元素之外的所有元素组成的集合。

3

isEmpty

如果集合为空,则此方法返回 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.++() 方法来连接两个或多个集合,但在添加集合时它会删除重复的元素。

以下是连接两个集合的示例。

示例

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.min 方法找出最小值,使用 Set.max 方法找出集合中可用元素的最大值。 以下是显示程序的示例。

示例

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.intersect 方法找出两个集合之间的共同值。 试试下面的例子来展示用法。

示例

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 时可以使用的重要方法。 有关可用方法的完整列表,请查看 Scala 的官方文档。

序号 带有描述的方法
1

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

使用附加元素创建一个新集合,除非该元素已经存在。

2

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

使用从该集合中移除的给定元素创建一个新集合。

3

def contains(elem: A): Boolean

如果 elem 包含在此集合中,则返回 true,否则返回 false。

4

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

返回一个新集合,该集合由该集合和给定集合中的所有元素组成。

5

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

返回这个集合和另一个集合的差。

6

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

使用传递的集合中的其他元素创建一个新的不可变集合

7

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

将此不可变集合与另一个集合的元素连接到此不可变集合。

8

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

返回一个新的不可变集合,该集合包含当前不可变集合的所有元素,除了每个给定参数元素少出现一次。

9

def addString(b: StringBuilder): StringBuilder

将此不可变集合的所有元素附加到字符串构建器。

10

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

使用分隔符字符串将此不可变集合的所有元素附加到字符串构建器。

11

def apply(elem: A)

测试此集合中是否包含某个元素。

12

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

计算不可变集合中满足谓词的元素的数量。

13

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

将此不可变集合的元素复制到数组中。

14

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

计算这个集合和另一个集合的差异。

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

测试谓词是否适用于此不可变集合的某些元素。

20

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

返回此不可变集合中满足谓词的所有元素。

21

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

查找满足谓词的不可变集合的第一个元素(如果有)。

22

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

测试一个谓词是否适用于这个不可变集合的所有元素。

23

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

将函数 f 应用于此不可变集合的所有元素。

24

def head: A

返回此不可变集合的第一个元素。

25

def init: Set[A]

返回除最后一个元素之外的所有元素。

26

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

计算这个集合和另一个集合之间的交集。

27

def isEmpty: Boolean

测试此集合是否为空。

28

def iterator: Iterator[A]

在可迭代对象中包含的所有元素上创建一个新的迭代器。

29

def last: A

返回最后一个元素。

30

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

通过将函数应用于此不可变集合的所有元素来构建新集合。

31

def max: A

找到最大的元素。

32

def min: A

找到最小的元素。

33

def mkString: String

在字符串中显示此不可变集合的所有元素。

34

def mkString(sep: String): String

使用分隔符字符串在字符串中显示此不可变集合的所有元素。

35

def product: A

返回此不可变集合的所有元素相对于 num 中的 * 运算符的乘积。

36

def size: Int

返回此不可变集合中的元素数。

37

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

返回由该不可变集合的前 n 个元素和其他元素组成的一对不可变集合。

38

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

如果这个集合是那个集合的一个子集,即如果这个集合的每个元素也是那个集合的一个元素,则返回 true。

39

def sum: A

相对于 num 中的 + 运算符,返回此不可变集合的所有元素的总和。

40

def tail: Set[A]

返回一个不可变集合,该集合由该不可变集合中除第一个元素之外的所有元素组成。

41

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

返回前 n 个元素。

42

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

返回最后 n 个元素。

43

def toArray: Array[A]

返回一个包含此不可变集合的所有元素的数组。

44

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

返回包含此不可变集合的所有元素的缓冲区。

45

def toList: List[A]

返回包含此不可变集合的所有元素的列表。

46

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

将此不可变集合转换为映射

47

def toSeq: Seq[A]

返回包含此不可变集合的所有元素的 seq。

48

def toString(): String

返回对象的字符串表示形式。

❮ Scala 集合