scala入门之高阶函数案例

高阶函数练习案例

1、定义一个高阶函数,按照指定的规则对集合里面的每个元素进行操作

	//比如: 对集合中每个元素进行操作,得到集合每个元素的长度
	def main(args: Array[String]): Unit = {
	  val arr = Array[String]("java", "python", "scala", "idea")
	  println(map(arr, _.length).toBuffer)
	}
	
	def map(arr: Array[String], operator: String => Int) = {
	  for (item <- arr) yield {
	    operator(item)
	  }
	}

2、定义一个高阶函数,按照指定的规则对集合中的所有元素进行聚合

	//比如:求得集合中的所有元素的和
	def main(args: Array[String]): Unit = {
	  val arr = Array[Int](1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
	
	  println(reduce(arr, _ + _))
	  println(reduce(arr, _ * _))
	}
	
	def reduce(arr: Array[Int], func: (Int, Int) => Int) = {
	  var tmp = arr(0)
	  for (i <- 1 until arr.length) {
	    tmp = func(tmp, arr(i))
	  }
	  tmp
	}

3、定义一个高阶函数,按照指定的规则获取指定元素

	//比如,获取年龄最大的
	def main(args: Array[String]): Unit = {
	  val arr = Array("zhangsan 20 3000", "fang 28 20000", "yire 15 90000")
	
	  println(sortBy(arr, _.split(" ")(1).toInt))
	  println(sortBy(arr, _.split(" ")(2).toInt))
	}
	
	def sortBy(arr: Array[String], func: (String) => Int) = {
	  var tmp = func(arr(0))
	  var result = arr(0)
	  for (i <- 1 until arr.length) {
	    val arrRes = func(arr(i))
	    if (arrRes > tmp) {
	      tmp = arrRes
	      result = arr(i)
	    }
	  }
	  result
	}

4、定义一个高阶函数,按照指定的规则对数据进行分组

//比如,按照性别分组
	def main(args: Array[String]): Unit = {
	  val arr = Array[String]("zhangsan 男 深圳", "lisi 女 深圳", "王五 男 北京")
	
	  println(sortBy1(arr, _.split(" ")(1)))
	  println(sortBy1(arr, _.split(" ")(2)))
	  println(sortBy2(arr, _.split(" ")(1)))
	  println(sortBy2(arr, _.split(" ")(2)))
	}
	
	//java的类来实现
	def sortBy1(arr: Array[String], func: String => String) ={
	  val result = new util.HashMap[String, util.ArrayList[String]]
	  for (elem <- arr) {
	    val key = func(elem)
	    if (result.containsKey(key)) {
	      result.get(key).add(elem)
	    } else {
	      val list = new util.ArrayList[String]()
	      list.add(elem)
	      result.put(key, list)
	    }
	  }
	  result
	}

    //scala的类实现
    def sortBy2(arr: Array[String], func: String => String) ={
      var result = Map[String, ArrayBuffer[String]]()
      for (elem <- arr) {
        val key = func(elem)
        if (result.contains(key)) {
          result(key) += elem
        } else {
          val list = ArrayBuffer[String]()
          list += elem
          result += (key -> list)
        }
      }
      result
    }

5、定义一个高阶函数,按照指定的规则对数据进行过滤,保留符合要求的数据

	//比如,过滤出偶数
	def main(args: Array[String]): Unit = {
	  val arr = Array[Int](10, 2, 4, 6, 1, 81, 13)
	
	  println(filter(arr, _ % 2 == 0).toBuffer)
	  println(filter(arr, _ % 3 == 0).toBuffer)
	}
	
	def filter(arr: Array[Int], func: Int => Boolean) = {
	  for (elem <- arr if func(elem)) yield {
	    elem.toInt
	  }
	}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序猿-瑞瑞

打赏不准超过你的一半工资哦~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值