Scala入门基础2集合
1》集合
1)Scala List(列表):List的特征是其元素以线性方式存储,集合中可以存放重复对象。
基本操作
def main(args: Array[String]) { // val siteList:List[String]=List("wang","huai","yu") val siteList="wang"::("huai"::("yu"::Nil)) println("列表的第一个元素"+siteList.head) println("除去第一个元素"+siteList.tail) println("列表是否为空"+siteList.isEmpty) }
列表链接
val siteList1=1::(2::(3::Nil)) val siteList2:List[Int]=List(4,5) val siteList3=siteList1:::siteList2 println(siteList3)
输出List(1, 2, 3, 4, 5)
使用 List.fill() 方法来创建一个指定重复数量的元素列表
val siteList2=List.fill(4)("wang")
println(siteList2)
输出List(wang, wang, wang, wang)
List.tabulate() 方法是通过给定的函数来创建列表。 def main(args: Array[String]) { val squares = List.tabulate(6)(n => n * n) println( "一维 : " + squares ) } 输出List(0, 1, 4, 9, 16, 25)
List.reverse 用于将列表的顺序反转,实例如下: val squares = List.tabulate(6)(n => n * n) println( "一维 : " + squares ) println("翻转顺序后:"+squares.reverse) 输出: 一维 : List(0, 1, 4, 9, 16, 25) 翻转顺序后:List(25, 16, 9, 4, 1, 0)
2)Scala Set(集合)是没有重复的对象集合,所有的元素都是唯一的。
定义集合
def main(args: Array[String]) { val mySet=Set(1,2,3) println(mySet.getClass.getName) println(mySet.exists(_ / 2== 0)) //true println(mySet.drop(1)) //Set(2,3) println(mySet)//Set(1, 2, 3) }
可变Set
import scala.collection.mutable.Set
加入这个引入后变为了可变set
val mySet=Set(1,2,3) println(mySet.getClass.getName) mySet.add(4) println(mySet)//Set(1, 2, 3, 4) mySet+=5 println(mySet)//Set(1, 5, 2, 3, 4) mySet.remove(1) println(mySet)//Set(5, 2, 3, 4) mySet-=2 println(mySet)//Set(5, 3, 4))
println(mySet)//Set(5, 3, 4)) println(mySet.head)//5 println(mySet.tail)//Set(3, 4) println(mySet.isEmpty)//false
链接集合
val mySet=Set(1,2,3) val mySet2=Set(4,6) var mySet3=mySet++mySet2; println(mySet3)//Set(1, 2, 6, 3, 4)
求Set的最大和最小值,set中可以直接使用max和min
println(mySet3.min) println(mySet3.max)
求交集
val mySet=Set(1,2,3) val mySet2=Set(3,4,6) println(mySet2.&(mySet))//Set(3)
Scala List 常用方法
下表列出了 Scala List 常用的方法:
序号 | 方法及描述 |
---|---|
1 |
def +:(elem: A): List[A] 为列表预添加元素 scala> val x = List(1)
x: List[Int] = List(1)
scala> val y = 2 +: x
y: List[Int] = List(2, 1)
scala> println(x)
List(1)
|
2 |
def ::(x: A): List[A] 在列表开头添加元素 |
3 |
def :::(prefix: List[A]): List[A] 在列表开头添加指定列表的元素 |
4 |
def :+(elem: A): List[A] 复制添加元素后列表。 scala> val a = List(1)
a: List[Int] = List(1)
scala> val b = a :+ 2
b: List[Int] = List(1, 2)
scala> println(a)
List(1)
|
5 |
def addString(b: StringBuilder): StringBuilder 将列表的所有元素添加到 StringBuilder |
6 |
def addString(b: StringBuilder, sep: String): StringBuilder 将列表的所有元素添加到 StringBuilder,并指定分隔符 |
7 |
def apply(n: Int): A 通过列表索引获取元素 |
8 |
def contains(elem: Any): Boolean 检测列表中是否包含指定的元素 |
9 |
def copyToArray(xs: Array[A], start: Int, len: Int): Unit 将列表的元素复制到数组中。 |
10 |
def distinct: List[A] 去除列表的重复元素,并返回新列表 |
11 |
def drop(n: Int): List[A] 丢弃前n个元素,并返回新列表 |
12 |
def dropRight(n: Int): List[A] 丢弃最后n个元素,并返回新列表 |
13 |
def dropWhile(p: (A) => Boolean): List[A] 从左向右丢弃元素,直到条件p不成立 |
14 |
def endsWith[B](that: Seq[B]): Boolean 检测列表是否以指定序列结尾 |
15 |
def equals(that: Any): Boolean 判断是否相等 |
16 |
def exists(p: (A) => Boolean): Boolean 判断列表中指定条件的元素是否存在。 判断l是否存在某个元素: scala> l.exists(s => s == "Hah")
res7: Boolean = true
|
17 |
def filter(p: (A) => Boolean): List[A] 输出符号指定条件的所有元素。 过滤出长度为3的元素: scala> l.filter(s => s.length == 3)
res8: List[String] = List(Hah, WOW)
|
18 |
def forall(p: (A) => Boolean): Boolean 检测所有元素。 例如:判断所有元素是否以"H"开头: scala> l.forall(s => s.startsWith("H")) res10: Boolean = false |
19 |
def foreach(f: (A) => Unit): Unit 将函数应用到列表的所有元素 |
20 |
def head: A 获取列表的第一个元素 |
21 |
def indexOf(elem: A, from: Int): Int 从指定位置 from 开始查找元素第一次出现的位置 |
22 |
def init: List[A] 返回所有元素,除了最后一个 |
23 |
def intersect(that: Seq[A]): List[A] 计算多个集合的交集 |
24 |
def isEmpty: Boolean 检测列表是否为空 |
25 |
def iterator: Iterator[A] 创建一个新的迭代器来迭代元素 |
26 |
def last: A 返回最后一个元素 |
27 |
def lastIndexOf(elem: A, end: Int): Int 在指定的位置 end 开始查找元素最后出现的位置 |
28 |
def length: Int 返回列表长度 |
29 |
def map[B](f: (A) => B): List[B] 通过给定的方法将所有元素重新计算 |
30 |
def max: A 查找最大元素 |
31 |
def min: A 查找最小元素 |
32 |
def mkString: String 列表所有元素作为字符串显示 |
33 |
def mkString(sep: String): String 使用分隔符将列表所有元素作为字符串显示 |
34 |
def reverse: List[A] 列表反转 |
35 |
def sorted[B >: A]: List[A] 列表排序 |
36 |
def startsWith[B](that: Seq[B], offset: Int): Boolean 检测列表在指定位置是否包含指定序列 |
37 |
def sum: A 计算集合元素之和 |
38 |
def tail: List[A] 返回所有元素,除了第一个 |
39 |
def take(n: Int): List[A] 提取列表的前n个元素 |
40 |
def takeRight(n: Int): List[A] 提取列表的后n个元素 |
41 |
def toArray: Array[A] 列表转换为数组 |
42 |
def toBuffer[B >: A]: Buffer[B] 返回缓冲区,包含了列表的所有元素 |
43 |
def toMap[T, U]: Map[T, U] List 转换为 Map |
44 |
def toSeq: Seq[A] List 转换为 Seq |
45 |
def toSet[B >: A]: Set[B] List 转换为 Set |
46 |
def toString(): String 列表转换为字符串 |
Scala 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 如果集合中含有子集返回 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 返回一个字符串,以对象来表示 |