Scala编程题目(必刷系列)

1、定义一个高阶函数,按照指定的规则对集合里面的每个元素进行操作
比如: Array(“hh”,“red”,“java”,“hadoop”)
规则: 对集合中每个元素进行操作,得到集合每个元素的长度。

  1. object Test01 {
      def main(args: Array[String]): Unit = {
        val list = Array(1,4,7,9,10,6,8,99,88,66)
        println(filter(list,(_%2==0)))
      }
     
      def filter(list: Array[Int],fun:(Int)=>Boolean) = {
          //用fun做守卫,过滤
        val res = for (elem <- list if (fun(elem))) yield {
          elem
        }
        res.toList
      }
    }

2、定义一个高阶函数,对数据中的元素按照指定的规则进行过滤
比如: Array(1,4,7,9,10,6,8,99,88,66)
规则: 只保留偶数数据

  1. object Test02 {
      def main(args: Array[String]): Unit = {
        val list = Array(10,4,6,10,2)
        println(poly(list,_+_))
      }
     
      def poly(list:Array[Int],fun:(Int,Int)=>Int) = {
        var res = list(0)
        for (i<-1 until list.size) res = fun(res,list(i))
        res
      }
    } 

 3、对数据中的元素按照指定规则进行分组
比如:Array(“zhangsan shenzhen man”,“lisi beijing woman”,“zhaoliu beijing man”)
规则: 按照地址进行分组

  1. object Test03 {
      def main(args: Array[String]): Unit = {
        val list = Array("zhangsan shenzhen man","lisi beijing woman","zhaoliu beijing man")
        println(group(list,_.split(" ")(2)))
      }
     
      def group(list:Array[String],fun:(String)=>String) = {
        val map = new util.HashMap[String,util.ArrayList[String]]()
        for (elem <- list) {
          val key = fun(elem)
          if(map.containsKey(key)){
            map.get(key).add(elem)
          }else{
            val value = new util.ArrayList[String]()
            value.add(elem)
            map.put(key,value)
          }
        }
        map
      }
    }

4、根据指定规则对数组所有元素聚合
比如:Array(10,4,6,10,2)
规则: 求和/求乘积

  1. object Test04 {
      def main(args: Array[String]): Unit = {
        val list = Array("zhangsan shenzhen man","lisi beijing woman","zhaoliu beijing man")
        println(group(list,_.split(" ")(2)))
      }
     
      def group(list:Array[String],fun:(String)=>String) = {
        val map = new util.HashMap[String,util.ArrayList[String]]()
        for (elem <- list) {
          val key = fun(elem)
          if(map.containsKey(key)){
            map.get(key).add(elem)
          }else{
            val value = new util.ArrayList[String]()
            value.add(elem)
            map.put(key,value)
          }
        }
        map
      }
    }

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值