Scala课后总结(8)

集合计算高级函数

过滤(filter)

从集合里挑出符合特定条件元素组成新集合 。比如从整数集合里选出偶数, list.filter(x => x % 2 == 0)  ,就是筛选出能被2整除的元素。

 转化/映射(map)

对集合每个元素应用一个函数,得到新元素组成新集合。像  list.map(x => x + 1)  ,会把集合里每个数都加1 。

 扁平化(flatten)

把嵌套集合(集合里元素还是集合)展开成单一层次集合。如  List(List(1, 2), List(3, 4))  经  flatten  后变为  List(1, 2, 3, 4)  。

 扁平化 + 映射(flatMap)

先对集合元素映射处理,再扁平化。例如对字符串集合按空格拆分后再合并, wordList.flatMap(x => x.split(" "))  。

 分组(groupBy)

按指定规则把集合元素分组。像  list.groupBy(x => x % 2)  ,会按元素除以2的余数把元素分组。

 简化(归约):通过某种运算把集合元素合并成一个值。

折叠:和归约类似,不过多了个初始值参与运算。

Reduce方法

 概念:通过特定逻辑聚合集合数据,减少数据量得到结果 。

Fold方法

概念:是  Reduce  简化的特殊情况

两个集合并

定义两个可变  Map : map1  和  map2  。

 用  foldLeft  方法将  map2  合并到  map1  ,遍历  map2  ,若  map1  有相同键则值相加,没有则添加键值对到  map1  ,最终得到合并后的  map3

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值