高阶函数中的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 复制代码
  }

}
相关推荐
SamDeepThinking1 小时前
从源码到代码:MyBatis-Flex 与 MyBatis-Plus 的逐项对比
java·后端·程序员
她的男孩4 小时前
Spring Boot 接 Flowable 工作流:用 3 个注解搭一个请假审批流程
java·后端·架构
荣码6 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
plainGeekDev7 小时前
Gson → kotlinx.serialization
android·java·kotlin
小bo波16 小时前
Java Swing 图形用户界面实验 —— 从算术练习到游戏开发的完整实践
java·课程设计·gui·游戏开发·扫雷·swing
咖啡八杯17 小时前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
SamDeepThinking1 天前
裁掉那个差程序员后,给你看团队里高手的代码:这个习惯,希望你有
java·后端·程序员
朕瞧着你甚好1 天前
技术雷达 & Java 集成评估报告 — Apache Tika 3.3.1
java·ai编程