Latest web development tutorials

Scala Set (coleção)

coleções Scala coleções Scala

Scala Set (cobrança) não é repetida coleção de objetos, todos os elementos são únicos.

coleção Scala é dividido em coleções de variáveis ​​e imutáveis.

Por padrão, o Scala usando coleções imutáveis, se você quiser usar o conjunto de variáveis, você precisa fazer referência pacotescala.collection.mutable.Set.

O scala.collection.immutable.Set referência padrão, conjunto imutável de exemplos são os seguintes:

val set = Set(1,2,3)
println(set.getClass.getName) // 

println(set.exists(_ % 2 == 0)) //true
println(set.drop(1)) //Set(2,3)

Se você precisar usar uma coleção variável preciso introduzir scala.collection.mutable.Set:

import scala.collection.mutable.Set // 可以在任何地方引入 可变集合

val mutableSet = Set(1,2,3)
println(mutableSet.getClass.getName) // scala.collection.mutable.HashSet

mutableSet.add(4)
mutableSet.remove(1)
mutableSet += 5
mutableSet -= 2

println(mutableSet) // Set(5, 3, 4)

val another = mutableSet.toSet
println(another.getClass.getName) // scala.collection.immutable.Set

Nota: Embora variável e imutável Set Set tem adicionar ou excluir elementos, mas há uma diferença muito grande.Uma operação Set imutável, vai produzir um novo conjunto, o conjunto original não mudou, o que é o mesmo que List. A operação de mudança do conjunto de variável é que a própria Conjunto, semelhante ao ListBuffer.


Coleção de operações básicas

coleção Scala tem três operações básicas:

  • head retorna o primeiro elemento da coleção
  • tail devolve um conjunto que contém, para além dos outros elementos do primeiro elemento
  • isEmpty retorna true se a coleção está vazia

Qualquer operação para coleções Scala pode ser usado para expressar as três operações básicas. Exemplos são os seguintes:

object Test {
   def main(args: Array[String]) {
      val site = Set("w3big", "Google", "Baidu")
      val nums: Set[Int] = Set()

      println( "第一网站是 : " + site.head )
      println( "最后一个网站是 : " + site.tail )
      println( "查看列表 site 是否为空 : " + site.isEmpty )
      println( "查看 nums 是否为空 : " + nums.isEmpty )
   }
}

Implementação do código acima, a saída é:

$ vim Test.scala 
$ scala Test.scala 
第一网站是 : w3big
最后一个网站是 : Set(Google, Baidu)
查看列表 site 是否为空 : false
查看 nums 是否为空 : true

conjunto de ligação

Você pode usar o operador++ ou Set.Método++ ()para conectar dois conjuntos. Se houver elementos duplicados irá remover elementos duplicados. Exemplos são os seguintes:

object Test {
   def main(args: Array[String]) {
      val site1 = Set("w3big", "Google", "Baidu")
      val site2 = Set("Faceboook", "Taobao")

      // ++ 作为运算符使用
      var site = site1 ++ site2
      println( "site1 ++ site2 : " + site )

      //  ++ 作为方法使用
      site = site1.++(site2)
      println( "site1.++(site2) : " + site )
   }
}

Implementação do código acima, a saída é:

$ vim Test.scala 
$ scala Test.scala 
site1 ++ site2 : Set(Faceboook, Taobao, Google, Baidu, w3big)
site1.++(site2) : Set(Faceboook, Taobao, Google, Baidu, w3big)

Encontrar os elementos mínimos e máximos da coleção

Você pode usar o métodoSet.min para encontrar o menor elemento na coleção, use Set.maxmaneira de encontrar o maior elemento na coleção. Exemplos são os seguintes:

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

      // 查找集合中最大与最小元素
      println( "Set(5,6,9,20,30,45) 集合中的最小元素是 : " + num.min )
      println( "Set(5,6,9,20,30,45) 集合中的最大元素是 : " + num.max )
   }
}

Implementação do código acima, a saída é:

$ vim Test.scala 
$ scala Test.scala 
Set(5,6,9,20,30,45) 集合中的最小元素是 : 5
Set(5,6,9,20,30,45) 集合中的最大元素是 : 45

interseção

Você pode usar o método ou métodosSet. & Set.intersectpara ver a interseção dos dois conjuntos de elementos. Exemplos são os seguintes:

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

      // 交集
      println( "num1.&(num2) : " + num1.&(num2) )
      println( "num1.intersect(num2) : " + num1.intersect(num2) )
   }
}

Implementação do código acima, a saída é:

$ vim Test.scala 
$ scala Test.scala 
num1.&(num2) : Set(20, 9)
num1.intersect(num2) : Set(20, 9)

Scala Set método comum

A tabela a seguir lista o conjunto Scala métodos comumente utilizados:

Não. Método e Descrição
1

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

Adicionar um novo elemento para a coleção, x e criar uma nova coleção, a menos que os elementos existentes

2

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

Removendo elementos da coleção, e criar uma nova coleção

3

def contém (elem: A): booleano

Se o elemento está presente na coleção, ele retorna true, caso contrário, retorna false.

4

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

Retorna a interseção de dois conjuntos

5

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

Retorna a diferença conjunto de dois conjuntos

6

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

Ao adicionar elementos de entrada da coleção especificada para criar um novo conjunto de imutáveis

7

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

Mesclando duas coleções

8

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

Através da remoção dos elementos do conjunto especificado passada para criar um novo conjunto de imutável

9

def addString (b: StringBuilder): StringBuilder

Adicione todos os elementos da coleção para o buffer de seqüência imutável

10

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

Adicionar todos os elementos de uma coleção imutável em um buffer de string, usando o delimitador especificado

11

def aplicar (elem: A)

Detectar se a coleção contém o elemento especificado

12

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

Calcule o número de elementos que atendem aos critérios especificados definidos

13

def copyToArray (xs: Array [A ], começar: Int, len: Int): Unidade

Copie elemento de coleção imutável para uma matriz

14

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

Diferença define comparando dois conjuntos

15

def cair (n: int): Ajuste [A]]

A nova coleção antes de retornar devoluções n elementos

16

def dropRight (n: int): Ajuste [A]

Voltar descartar os últimos n elementos da nova coleção

17

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

elemento de descarte esquerda para a direita, até que a condição não for satisfeita p

18

def equals (que: Qualquer): booleano

é igual método pode ser utilizado em qualquer sequência. Para a comparação da série são iguais.

19

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

Analisando conjunto imutável o elemento condições especificado existe.

20

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

Saída atende a todos os elementos da coleção imutáveis ​​critérios especificados.

21

def encontrar (p: (A) => Boolean): Opção [A]

Encontrar o primeiro elemento da coleção encontram imutável aos critérios especificados

22

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

Localizar todos os elementos de uma coleção imutável que atenda aos critérios especificados

23

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

A função é aplicada a todos os elementos da recolha imutável

24

cabeça def: A

Obter o primeiro elemento da coleção imutável

25

o init def: Ajuste [A]

Retorna todos os elementos, exceto o último

26

def cruzam (que: Set [A ]): Set [A]

Calcular a interseção de dois conjuntos

27

def isEmpty: Boolean

Determinar se a coleção está vazia

28

def iterator: Iterator [A]

Criar um novo iterador para percorrer os elementos

29

def última: Um

Retorna o último elemento

30

DEF mapear [B] (f: (A) => B): immutable.Set [B]

Através de um determinado método irá recalcular todos os elementos

31

def máx: A

Localizar o elemento máximo

32

min DEF: Um

Encontre o menor elemento

33

def mkString: String

O conjunto de todos os elementos do mostrador como uma string

34

def mkString (sep: String): Cordas

Separadores vai reunir todos os elementos apresentados como uma string

35

produto def: A

Retorna um conjunto imutável de números nos elementos do enredo.

36

tamanho def: Int

Retorna o número de elementos na coleção imutável

37

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

A recolha imutável é dividido em dois recipientes, o primeiro por os primeiros n elementos, e a segunda por os elementos restantes

38

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

Se a coleção contém um subconjunto retorna verdadeiro, caso contrário false

39

soma def: A

Retorna um conjunto imutável de todos os elementos do digital e

40

tail def: Ajuste [A]

Retorna um conjunto imutável de outros elementos além do primeiro elemento

41

def tomar (n: int): Ajuste [A]

Retorna os primeiros n elementos

42

def takeRight (n: int): Ajuste [A]

n elementos Voltar

43

def toArray: Array [A]

Será convertido para um colecção digital

44

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

buffer de fundo, contém todos os elementos de uma coleção de imutáveis

45

ToList def: Lista [A]

Lista de volta, contém todos os elementos de uma coleção de imutáveis

46

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

Voltar Mapa, contém todos os elementos de uma coleção de imutáveis

47

def toSeq: Seq [A]

Voltar Seq, contém todos os elementos de uma coleção de imutáveis

48

toString def (): String

Retorna uma cadeia de se opor a representar

Mais maneiras para se referir a documentação da API

coleções Scala coleções Scala