高阶函数中的reduce,reduceleft,fold

Scala 复制代码
object Test_gjhs2 {
  def main(args: Array[String]): Unit = {

reduce:

Scala 复制代码
    //定义一个数组
    Array(1,2,3,4,5)
    //求和 (1,2,3,4,5) ===> 一个值
    val res = Array(1,2,3,4,5).reduce((x,y)=> x+y)
    println(res)//15
Scala 复制代码
    val res2 = Array(1,2,3,4).reduceLeft((x,y)=> x - y) //-8
    val res3 = Array(1,2,3,4).reduceRight((x,y)=> x - y)//-2
    println(res2,res3) 
Scala 复制代码
    val res4 = Array(-1,2,10,55).reduce((a,b)=>{
  if(a>b)a else b   //求最大值
})
    println(res4)//55 
Scala 复制代码
val res5 = Array(-1,2,10,55).reduce((a,b)=>{
  if(a<b)a else b   //求最小值
})
    println(res5)

fold :

Scala 复制代码
    //    fold:作用:带初始值的reduce
//          格式:fold(初始值)(二元函数=>返回值)
    val res1 = Array(1000,1500,1200,1800,2000).fold(100000)((x,y)=>if(x>y) y else x)
    println(res1)//1000
Scala 复制代码
    //   排序
//    sorted:按自然顺序对数组元素排序(数字:从小到大,字母:字典顺序),返回排序之后的新数组
//    var arr1 Array(1.2,0,1.3,-1).sorted
//    主要不要加()
    var arr1 =Array("a","b","apple","park","zoom","school" ).sorted
//    //打印一个数组
//    arr1.foreach(println)
    //sortWith:排序函数返回true表示第一个元素应该排在第二个元素之前
//    Array(-1,0,1,3,2).sortWith((a,b)=>bollean)
    //数字a,到0点的距离是|a-0|
    Array(-1,0,1,3,2).sortWith((a,b)=>Math.abs(a-0) < Math.abs(b-0) ).foreach(println)//0 -1 1 2 3
    //练习:按它们到2点的距离从大到小排序
    Array(-1,0,1,3,2).sortWith((a,b)=>Math.abs(a-2) > Math.abs(b-2) ).foreach(println)//-1 0 1 3 2
Scala 复制代码
  }

}
相关推荐
java叶新东老师17 分钟前
goland编写go语言导入自定义包出现: package xxx is not in GOROOT (/xxx/xxx) 的解决方案
开发语言·后端·golang
找不到、了20 分钟前
Java排序算法之<插入排序>
java·算法·排序算法
设计师小聂!29 分钟前
力扣热题100----------53最大子数组和
java·数据结构·算法·leetcode
檀越剑指大厂44 分钟前
【Python系列】Flask 应用中的主动垃圾回收
开发语言·python·flask
檀越剑指大厂1 小时前
【Python系列】使用 memory_profiler 诊断 Flask 应用内存问题
开发语言·python·flask
笠码1 小时前
JVM Java虚拟机
java·开发语言·jvm·垃圾回收
thginWalker1 小时前
八股文之JVM
java
橙小花1 小时前
C语言:指针、变量指针与指针变量、数组指针与指针数组
c语言·开发语言
Cyanto1 小时前
MyBatis-Plus高效开发实战
java·开发语言·数据库
qhd吴飞1 小时前
mybatis 差异更新法
java·前端·mybatis