开发者社区> 问答> 正文

怎样简单明了的解释KMP算法

怎样简单明了的解释KMP算法

展开
收起
知与谁同 2018-07-17 14:52:54 1564 0
1 条回答
写回答
取消 提交回答
  • map 根据输入的映射函数,将一个集合映射为另一个集合,比如:
    输入集合为 {1,2,3,4,5},输入的函数为 f(x) = x^2,那么输出的集合就是 {1,4,9,16,25}。

    reduce 就是根据输入的归约函数,将集合(一般指map输出的集合)归约,比如上面的输出集合是 {1,4,9,16,25},假设我们的归约函数是 f(x,y) = x + y, 那么 reduce 的过程就是 {5,9,16,25} -> {14,16,25} -> {30,25} -> {55}。

    我们使用 Java8 来描述这个过程:
    int result = IntStream.range(1, 6) // 获得集合 {1,2,3,4,5} .map(x -> x * x) // 映射为 {1,4,9,16,25} .reduce((x, y) -> x + y) // 归约 .getAsInt(); // 获得结果System.out.println(result);结果:
    2019-07-17 22:55:55
    赞同 展开评论 打赏
问答分类:
问答标签:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
数据+算法定义新世界 立即下载
袋鼠云基于实时计算的反黄牛算法 立即下载
Alink:基于Apache Flink的算法平台 立即下载