reduce 是一种集合操作,用于对集合中的元素进行聚合操作,返回一个单一的结果。它通过指定的二元操作(即取两个元素进行操作)对集合中的所有元素进行递归处理,并最终将其合并为一个值。
// reduce ==== reduceLeft 从左向右计算
// reduceRight 从右向左计算
def main(args: Array[String]): Unit = {
val arr = Array(1,2,3)
val rst = arr.reduceLeft( (x,y)=> x - y )
val rst1 = Array(1,2,3,4).reduceRight( (x,y)=> x - y )
println(s"rst = ${rst}")
println(s"rst1 = ${rst1}")
}
fold 是一种集合操作(与reduce类似),用于对集合中的元素进行聚合操作,返回一个单一的结果,需要提供一个初始的“种子”值。
// fold:带初值的reduce
def main(args: Array[String]): Unit = {
val rst = Array(1,2,3).fold(10)((x,y)=>x+y)
println(s"rst = ${rst}") // 16
}
sorted对元素进行排序。它会直接使用元素自身的自然顺序进行排序
// sorted: 排序
def main(args: Array[String]): Unit = {
// 对数值元素排序: 从小到大排序
var arr = Array(-1,10,-2,1,2,3).sorted
arr.foreach(println)
// 对字符元素排序,字典顺序
var arr2 = Array("zoom", "bus","apple", "banana", "car").sorted
arr2.foreach(println)
}
sortWith: 自定义排序
sortWith ((x,y) => 布尔值 )
//sortWith: 自定义排序
// sortWith ((x,y) => 布尔值 )
// (1) 如果返回值是 true,那么 x 就在 y 的前面
// (1) 如果返回值是 false,那么 x 就在 y 的后面
def main(args: Array[String]): Unit = {
// 对数值元素排序:按照离 1 这个点的距离的从小到大排序
var arr = Array(-1,10,-2,1,2,3).sortWith((x,y) => Math.abs(x - 1) < Math.abs(y - 1))
arr.foreach(println)
}