美文网首页
函数式编程学习

函数式编程学习

作者: peerben | 来源:发表于2016-03-12 11:58 被阅读34次

Swift Functional Programming Tutorial

烧脑体操(三)
烧脑体操(四)

这几天学习了一下函数式编程,简直是思维上的颠覆,代码可以这样思考。

这篇文章简略的Filter和reduce实现

func myFilter<T>(source: [T], predicate:(T) -> Bool) -> [T] {
    var result = [T]()
    for i in source {
        if predicate(i) {
            result.append(i)
        }
    }
    return result
}

extension Array {
    func myReduce<T, U>(seed:U, combiner:(U, T) -> U) -> U {
        var current = seed
        for item in self {
            current = combiner(current, item as T)
        }
        return current
    }
}

最后给出一个例子

let words = ["Cat", "Chicken", "fish", "Dog",
                      "Mouse", "Guinea Pig", "monkey"]

实现对单词的首字母归类
[("C", ["Cat", "Chicken"]), ("F", ["fish"]), ("D", ["Dog"]), ("M", ["Mouse", "monkey"]), ("G", ["Guinea Pig"])]

我给出的常规的实现

typealias Entry = (Character, [String])

func buildIndex(words:[String]) -> [Entry]{
    
    var entryList = [Entry]()
    
    for word in words {
        let firstLetter = word.uppercaseString[word.startIndex]
        
        var find = false
        for (index, entry) in entryList.enumerate() {
            if firstLetter == entry.0 {
                find = true
                /*
                entry.1.append(word)
                //重点!!一定要记住值类型和引用类型
                //entry是值类型
                entryList[index] = entry
                */
                //优化
                entryList[index].1.append(word)
            }
        }
        
        if !find {
            let entry : (Character, [String]) = (firstLetter, [word])
            entryList.append(entry)
        }
    }
    
    return entryList
}

改为函数式编程的实现

let compute = words.reduce([]) { (var arr, word) -> [Character] in
    let letter = word.uppercaseString[word.startIndex]
    if !arr.contains(letter) {
        arr.append(letter)
    }
    return arr
}.map { (letter) -> Entry in
    return (letter, words.filter({ (word) -> Bool in
        return word.uppercaseString[word.startIndex] == letter
    }))
}

觉得比文章的实现要好

相关文章

  • 函数式编程

    为什么学习函数式编程 函数式编程随着react的流行受到越来越多的关注 vue3也开始拥抱函数式编程 函数式编程可...

  • 函数式编程

    1 文章目标 为什么要学习函数式编程以及什么是函数式编程 函数式编程的特性(纯函数、柯里化、函数组合等) 函数式编...

  • Scala 学习笔记

    Scala 学习笔记 1.函数式编程 函数式编程:函数式编程把函数当作一等公民,充分利用函数,支持函数的多种使用方...

  • 函数式编程

    拉勾大前端的笔记,仅作为学习记录 课程介绍 为什么学习函数式编程,以及什么是函数编程 函数式编程的特性(纯函数,柯...

  • Python进阶语法——函数式编程、模块,面向对象

    一、 Python进阶学习 一、函数式编程 1.1函数式编程 1.2高阶函数 1.2.1 import mathd...

  • Haskell学习-函数式编程初探

    原文地址:Haskell学习-函数式编程初探  为什么要学习函数式编程?为什么要学习Haskell?  .net到...

  • RxSwift初探(1)

    一、前提:函数响应式编程思想 简单来说 函数响应式编程 = 函数式编程 + 响应式编程 (1)函数式 函数式编程是...

  • iOS 函数编程 & 链式编程

    函数式(链式)编程 函数式编程概念 函数式编程是种编程范式 函数式编程 Functional Programmin...

  • Scala 函数式编程(一) 什么是函数式编程?

    为什么我们需要学习函数式编程?或者说函数式编程有什么优势?这个系列中我会用 scala 给你讲述函数式编程中的优势...

  • 函数式编程 响应式编程

    学习函数式编程对于我们理解Masonry && Snapkit有很大的帮助,函数式编程(链式编程)。下面文章也是参...

网友评论

      本文标题:函数式编程学习

      本文链接:https://www.haomeiwen.com/subject/haexlttx.html