(一)filter函数
作用:对数组元素使用函数进行过滤。
语法:新数组= 旧数组.filter(元素=>bool) 它的参数是一个函数,这函数的返回值是布尔值。如果返回为true就保留。
任务:在数组中找出元素是偶数的,并组成新数组。(1,2,3,4,5) → (2,4)
def main(args: Array[String]): Unit = {
// 把数值为偶数的留下来
val arr1 = Array(1,2,3,4,5)
// val arr2 = arr1.filter(x => {
// println(x)
// x%2 == 0
// })
val arr2 = arr1.filter(x => x%2==0)
arr2.foreach(println)
练习:把小于80分的去掉,只保留大于80分的分数
var score = Array(90,98,60,49,100)
//把小于80分的去掉,只保留大于80分的分数
val score2 = score.filter(x => x > 80)
score2.foreach(println)
(二)foreach函数
作用:对数组的每一个元素应用函数。
语法:数组.foreach(元素=>{})
arr2.foreach(println)
(三)reduce
作用: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}")
(四)reduceLeft-reduceRight
作用:reduceLeft是从集合的左侧开始聚合,与reduce等价; reduceRight是从集合的右边开始。
语法:数组.reduceLeft(reduceRight)(元素=>{})
val arr = Array(1,2,3,4,5)
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}")