Scala Set (coleção)
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