java8中的map和reduce

java8中最受人期待的就是lambda,引入了map和reduce。map和reduce可以构成几乎所有的函数式操作。


map

        final List<Integer> numbers = Arrays.asList(1, 2, 3, 4);
        final List<Integer> doubleNumbers = numbers.stream()
                .map(number -> number * 2)
                .collect(Collectors.toList());

结果:[2, 4, 6, 8]

也可以搞成其他的类型,初始List是Integer,也可以变成String

        final List<Integer> numbers = Arrays.asList(1, 2, 3, 4);
        final List<String> numberIndex = numbers.stream()
                .map(number -> "#" +

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
贝叶斯文本分类器是一种常用的机器学习算法,可以用于将文本数据进行分类。基于JavaMap/ReduceMapReduce)框架实现贝叶斯文本分类器的设计可以分为以下几个步骤: 1. 数据预处理:首先,需要将文本数据进行预处理,包括去除停用词、标点符号、数字等非关键信息,并进行分词操作,将每个文本分割成一个个词语。 2. 计算词语频率:使用Map/Reduce框架,将每个文本的词语作为键,将出现的频率作为值进行统计。Map阶段将每个文本拆分成词语,并为每个词语设置初始频率为1。Reduce阶段将相同的词语进行合并,并计算总频率。 3. 计算词语条件概率:对于每个类别,需要计算每个词语的条件概率。通过Map阶段将每个词语与它所属的类别作为键值对进行传输。Reduce阶段将相同的词语进行合并,并统计该词语在每个类别的频率。 4. 计算类别概率:通过Map/Reduce框架,将每个文本的类别作为键进行传输。Reduce阶段将相同的类别进行合并,并统计该类别在整个文本集的频率。 5. 应用贝叶斯公:对于一个新的文本,首先将其进行预处理,并计算出每个词语在各个类别的条件概率。然后,根据贝叶斯公,将各个词语的条件概率相乘,再乘以各个类别的概率,最终得到该文本属于每个类别的概率。根据概率大小,将文本分类到最可能的类别。 以上就是基于JavaMap/Reduce实现的贝叶斯文本分类器的设计。这种设计可以充分利用Map/Reduce框架的并行计算能力,加快计算速度,提高分类器的效率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值