一、reduce
作用:reduce 是一种集合操作,用于对集合中的元素进行聚合操作,返回一个单一的结果。它通过指定的二元操作(即取两个元素进行操作)对集合中的所有元素进行递归处理,并最终将其合并为一个值。
def main(args: Array[String]): Unit = {
//定义一个数组
val arr=Array(1,2,3,4,5)
val rst=arr.reduce((x,y) =>x+y)
println(s"rst=${rst}")//15
}
二、reduceLeft-reduceRight
reduceLeft是从集合的左侧开始聚合,与reduce等价; reduceRight是从集合的右边开始。
def main(args: Array[String]): Unit = {
//定义一个数组
val arr=Array(1,2,3,4)
//从左算
val rst_left=arr.reduceLeft((x,y) =>x-y)
//从右算
val rst_right=arr.reduceRight((x,y) =>x-y)
println(s"rst_left=${rst_left}")//-8
println(s"rst_right=${rst_right}")//-2
}
三、fold
作用:fold 是一种集合操作(与reduce类似),用于对集合中的元素进行聚合操作,返回一个单一的结果,需要提供一个初始的“种子”值。
def main(args: Array[String]): Unit = {
//定义一个数组
val arr=Array(1,2,3,4)
//10就是初始值
val rst=arr.fold(10)((x,y) => x+y)
println(s"rst=${rst}")//20
}
四、sorted函数
功能:对元素进行排序。它会直接使用元素自身的自然顺序进行排序
//sorted排序
def main(args: Array[String]): Unit = {
//定义一个数组
// val arr=Array(-1,20,3,40)
//
// var arr1=arr.sorted
//
// arr1.foreach(println)
//对数值进行排序:从小到大进行排序
Array(-1,20,-100,3,40).sorted.foreach(println)
//对字符排序:按照字典顺序
Array("zip","bus","apple","banana","card").sorted.foreach(println)
}
五、sortedWith
//sortWith 自定义排序规则
def main(args: Array[String]): Unit = {
//对数值进行排序:按离0点的距离大小进行排序
//sortWith( (x,y) =>布尔值 )
// true: x 应该要排在y的前面
// false: x要排在y的后面
//Array(-1,2,0,4,9).sortWith((x,y)=>Math.abs(x - 0)<Math.abs(y-0)).foreach(println)
//Array(-1,2,0,4,9).sorted.foreach(println)//从小到大排序
//任务:从小到大排序?
Array(-1,2,0,4,9).sortWith((x,y)=>x>y).foreach(println)
}