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

}
相关推荐
咖啡教室2 分钟前
java日常开发笔记和开发问题记录
java
咖啡教室8 分钟前
java练习项目记录笔记
java
鱼樱前端1 小时前
maven的基础安装和使用--mac/window版本
java·后端
RainbowSea1 小时前
6. RabbitMQ 死信队列的详细操作编写
java·消息队列·rabbitmq
RainbowSea1 小时前
5. RabbitMQ 消息队列中 Exchanges(交换机) 的详细说明
java·消息队列·rabbitmq
我不会编程5553 小时前
Python Cookbook-5.1 对字典排序
开发语言·数据结构·python
李少兄3 小时前
Unirest:优雅的Java HTTP客户端库
java·开发语言·http
此木|西贝3 小时前
【设计模式】原型模式
java·设计模式·原型模式
可乐加.糖3 小时前
一篇关于Netty相关的梳理总结
java·后端·网络协议·netty·信息与通信
无名之逆3 小时前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust