美文网首页
第六讲 Set

第六讲 Set

作者: 农民工进城 | 来源:发表于2018-04-03 19:57 被阅读0次

Set(集合)是没有重复的对象集合,所有的元素都是唯一的。
Scala 集合分为可变的和不可变的集合。
默认情况下,Scala 使用的是不可变集合,如果你想使用可变集合,需要引用 scala.collection.mutable.Set 包;默认引用 scala.collection.immutable.Set。

注意: 虽然可变Set和不可变Set都有添加或删除元素的操作,但是有一个非常大的差别。对不可变Set进行操作,会产生一个新的set,原来的set并没有改变,这与List一样。 而对可变Set进行操作,改变的是该Set本身,与ListBuffer类似。

本章要点

-Set 创建
-Set 遍历
-有关Set 的其他操作

集合实例如下:

   val set= Set(1,2,3,3,4)   
   set.foreach(x=>print(x))//结果是:1,2,3,4,不重复自动去重

遍历:

   val set= Set(1,2,3,3,4) 
   for(x<- set){
     print(x+" ")
   }
   println()
   set.foreach(x=>print(x+""))

基本操作:
Scala集合有三个基本操作:
head 返回集合第一个元素
tail 返回一个集合,包含除了第一元素之外的其他元素
isEmpty 在集合为空时返回true
对于Scala集合的任何操作都可以使用这三个基本操作来表达。实例如下:

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

      println( "第一网站是 : " + site.head )
      println( "最后一个网站是 : " + site.tail )
      println( "查看列表 site 是否为空 : " + site.isEmpty )
      println( "查看 nums 是否为空 : " + nums.isEmpty )
   }
}
  • 交集:intersect ,&
    val set1 = Set(1,2,3,4,4)
    val set2 = Set(1,2,5)
    val set3 = set1.intersect(set2)
    val set4 = set1.&(set2)
  • 差集: diff ,&~
   set1.diff(set2).foreach { println }
   set1.&~(set2).foreach { println }
  • 子集:subsetOf
   set1.subsetOf(set2)//是否是子集
  • 最大:max
   println(set1.max)
  • 最小:min
   println(set1.min)
  • 转成数组
   set1.toArray.foreach{println}
  • toList
   set1.toList.foreach{println}
  • 转成字符串:mkString(“~”)
  println(set1.mkString)
   println(set1.mkString("\t"))

Set 其他常用方法

下表列出了 Scala Set 常用的方法:
序号 方法及描述

  1. def +(elem: A): Set[A]
    为集合添加新元素,x并创建一个新的集合,除非元素已存在
  2. def -(elem: A): Set[A]
    移除集合中的元素,并创建一个新的集合
  3. def contains(elem: A): Boolean
    如果元素在集合中存在,返回 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]
    从左向右丢弃元素,直到条件p不成立
  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
    将函数应用到不可变集合的所有元素
  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
    返回不可变集合中数字元素的积。
  36. def size: Int
    返回不可变集合元素的数量
  37. def splitAt(n: Int): (Set[A], Set[A])
    把不可变集合拆分为两个容器,第一个由前 n 个元素组成,第二个由剩下的元素组成
  38. def subsetOf(that: Set[A]): Boolean
    如果集合A中含有子集B返回 true,否则返回false
  39. def sum: A
    返回不可变集合中所有数字元素之和
  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]
    返回 List,包含了不可变集合的所有元素
  46. def toMap[T, U]: Map[T, U]
    返回 Map,包含了不可变集合的所有元素
  47. def toSeq: Seq[A]
    返回 Seq,包含了不可变集合的所有元素
  48. def toString(): String
    返回一个字符串,以对象来表示

相关文章

  • 第六讲 Set

    Set(集合)是没有重复的对象集合,所有的元素都是唯一的。Scala 集合分为可变的和不可变的集合。默认情况下,S...

  • redis 第七讲 Set

    单值多value sadd / smembers / sismember scard 获取集合里面的元素个数 sr...

  • 亚老师关于阅读的第六次讲座

    昨天没讲啊,讲多了哇,同学们接受不了,现在呢。我接着讲第六讲啊,第六讲讲完以后呢,还有俩讲这个记叙文呐。一些...

  • 2020第六讲做个聪明的病人

    做个聪明的病人第六讲

  • 第六讲复讲

    “首孝悌”,“首”是说做人的根本在哪里,在孝和悌上,尊敬长辈,友爱兄弟。其中一个“悌”字包含了一个很重要的态度,就...

  • 第六讲

    一句几点了,看似简单,其实蕴藏了很深的道理,首先他让孩子建立了时间观念,其次他也需要给孩子配备相应的手表或手环等硬...

  • 第六讲

    第六讲 小作文训练:记叙文中的议论抒情。 记叙文的筋骨是记叙,血肉是描写,灵魂是议论和抒情。 例文升格训练。 找准...

  • 第六讲

    第六讲:政治的性质 (阅读文本:亚里士多德《政治学》第一卷) 好,我们继续。从今天开始,进入到西方古代政治思想的第...

  • 第六讲

    伊壁鸠鲁看来,一个人想要获得灵魂的安宁,享受人生的幸福,就必须认识宇宙自然的本性。 根据原子论,宇宙是无数的物质原...

  • 第六讲

    经验内在的微妙能量·梦的层面·怎样进入禅定·止和观的平衡 经验内在的微妙能量 这个冥想意味着有一个前提——必须首先...

网友评论

      本文标题:第六讲 Set

      本文链接:https://www.haomeiwen.com/subject/wbychftx.html