1.reduce
reduce 是一种集合操作,用于对集合中的元素进行聚合操作,返回一个单一的结果。它通过指定的二元操作(即取两个元素进行操作)对集合中的所有元素进行递归处理,并最终将其合并为一个值。
val numbers = List(1, 2, 3, 4, 5)
val sum = numbers.reduce((a, b) => a + b)
println(sum) // 输出: 15
2.reduceLeft-reduceRight
reduceLeft是从集合的左侧开始聚合,与reduce等价; reduceRight是从集合的右边开始。
println( Array(1,2,3).reduceRight((x,y)=>x-y) ) // (1 - (2 - 3)) = (1 - (-1)) = 2
println( Array(1,2,3).reduceLeft((x,y)=>x-y) ) // ((1-2)-3)
3.fold
fold 是一种集合操作(与reduce类似),用于对集合中的元素进行聚合操作,返回一个单一的结果,需要提供一个初始的“种子”值。
List[Int] = List(1, 2, 3, 4, 5)
list.fold(10)((a,b)=>a * b) // 1200
4.List[Int] = List(1, 2, 3, 4, 5)
list.fold(10)((a,b)=>a * b) // 1200
5.sorted函数
sorted 是 Scala 集合中用于自然排序的核心函数,核心作用是:对集合元素按 “自然顺序”(默认排序规则)进行升序排列,返回排序后的新集合(原集合保持不变,满足函数式 “不可变” 特性)。
// 对数值排序
Array(1.2,0,1.3,-1).sorted.foreach(println)
// 对字符串进行排序
Array("apple", "a", "about","busy","student").sorted.foreach(println)