(一)filter函数
- 作用:对数组元素使用函数进行过滤
- 语法:新数组= 旧数组.filter(元素=>bool) 它的参数是一个函数,这函数的返回值是布尔值。如果返回为true就保留。
eg1:
object basss123 {
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)
var score = Array(90, 98, 60, 49, 100)
//把小于80的分值去掉
score.filter(x => 80).foreach(println)
}
}
(二)reduce函数
-
作用:reduce 是一种集合操作,用于对集合中的元素进行聚合操作,返回一个单一的结果。它通过指定的二元操作(即取两个元素进行操作)对集合中的所有元素进行递归处理,并最终将其合并为一个值。
-
语法:语法:reduce 函数需要一个函数作为参数,这个函数接受两个相同类型的参数,并返回一个值。
eg2:
object basee1 {
def main(args:Array[String]):Unit={
val arr = Array(1,2,3,4,5)
//求数组元素的累加
val rst =arr.reduce ((x,y)=> x + y)
// val rst =arr .sum
println(s"rst = ${rst}") //rst=15
}
}
reduceLeft-reduceRight
- reduceLeft是从集合的左侧开始聚合,与reduce等价;
- reduceRight是从集合的右边开始。
eg3:
object basee1 {
def main(args:Array[String]):Unit={
val arr = Array(1,2,3)
val rst=arr.reduceLeft((x,y)=>x-y)
println(s"rst = ${rst}") //-4
}
}
(三) fold函数
- 作用:fold 是一种集合操作(与reduce类似),用于对集合中的元素进行聚合操作,返回一个单一的结果,需要提供一个初始的“种子”值。
- 语法:组.fold(初值)(函数)
eg4:
object basee1 {
// 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
eg5:
object basee1 {
// 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)
}
}
结果:
(五) soreWith函数
- 功能:按自定义规则排序
- 语法:新数组 = 原数组.sortedWith(排序函数)
- 排序函数:(元素a,元素b)=>Bool。如果返回 true,则 表示元素a应排在元素b之前。
eg6:
object basee1 {
// sortedWith: 自定义排序
// sortwith((x,y)=>布尔值)
// (1) 如果返回值是ture ,那么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)
}
}
- 完结撒花 !!!!!!!!!!
- 制作不易 希望·一键三连 在此感谢关注的粉丝宝宝
- 新来的宝宝可以关注下主播哟!!!!!