其他分享
首页 > 其他分享> > 集合计算高级函数

集合计算高级函数

作者:互联网

集合计算高级函数

(1)过滤

(2)转化/映射

(3)扁平化

(4)扁平化+映射 注:flatMap相当于先进行map操作,在进行flatten操作

(5)分组

(6)简化(规约)

(7)折叠

object TestList {

   def main(args: Array[String]): Unit = {

       val list: List[Int] = List(1, 2, 3, 4, 5, 6, 7, 8, 9)
       val nestedList: List[List[Int]] = List(List(1, 2, 3), List(4, 5, 6), List(7, 8, 9))
       val wordList: List[String] = List("hello world", "hello atguigu", "hello scala")

       //(1)过滤
       println(list.filter(x => x % 2 == 0))

       //(2)转化/映射
       println(list.map(x => x + 1))

       //(3)扁平化
       println(nestedList.flatten)

       //(4)扁平化+映射 注:flatMap相当于先进行map操作,在进行flatten操作
       println(wordList.flatMap(x => x.split(" ")))

       //(5)分组
       println(list.groupBy(x => x % 2))
  }
}

疑惑:

filter函数:返回一个List,其参数是一个返回Boolean类型的函数,如果返回值为true,则该元素返回。如果我们想保留list中的偶数,可以使用如下方法:

x => x % 2 == 0:匿名函数:

复习匿名函数:没有名字的函数就是匿名函数。

(x:Int)=>{函数体}
x:表示输入参数类型;Int:表示输入参数类型;函数体:表示具体代码逻辑
// (1)定义一个函数:参数包含数据和逻辑函数
def operation(arr: Array[Int], op: Int => Int) = {
for (elem <- arr) yield op(elem)
}

// (2)定义逻辑函数
def op(ele: Int): Int = {
ele + 1
}

// (3)标准函数调用
val arr = operation(Array(1, 2, 3, 4), op)
println(arr.mkString(","))

// (4)采用匿名函数
val arr1 = operation(Array(1, 2, 3, 4), (ele: Int) => {
ele + 1
})
println(arr1.mkString(","))

// (4.1)参数的类型可以省略,会根据形参进行自动的推导;
val arr2 = operation(Array(1, 2, 3, 4), (ele) => {
ele + 1
})
println(arr2.mkString(","))

// (4.2)类型省略之后,发现只有一个参数,则圆括号可以省略;其他情况:没有参数和参数超过1的永远不能省略圆括号。
val arr3 = operation(Array(1, 2, 3, 4), ele => {
ele + 1
})
println(arr3.mkString(","))

// (4.3) 匿名函数如果只有一行,则大括号也可以省略
val arr4 = operation(Array(1, 2, 3, 4), ele => ele + 1)
println(arr4.mkString(","))

//(4.4)如果参数只出现一次,则参数省略且后面参数可以用_代替
val arr5 = operation(Array(1, 2, 3, 4), _ + 1)
println(arr5.mkString(","))

 

标签:函数,Int,List,高级,ele,println,参数,集合
来源: https://www.cnblogs.com/Sofiacodes/p/16390702.html