第六讲 Set

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
    返回一个字符串,以对象来表示
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容