今天公司大佬给我们分享了一堂关于函数式编程的课,其中有三个小练习我觉得很有意思,很经典。让我感觉函数式编程很强大,能把很复杂的内容用短短几行代码,在这里分享给大家。
案例一:程序员排名实现程序员排名,有如下要求:
??只有代码量大于100行的程序员才参加排名; ?根据单行代码行缺陷率进行排名,缺陷率越小,排名越高。缺陷率=bug数/代码行数; ?缺陷率相同,按照代码行数进行排名,行数越多,排名越高; ?输出程序员排名列表,排名高的在后面。 ?代码如下
???案例二:完美数如果一个自然数恰好等于他的真因子之和,则称该数为完美数。
例如:第一个完美数是6,他有约数1、2、3、6,除去它本身6外,其余3个数相加,1+2+3=6。
第二个完美数是28,他有约数1、2、4、7、14、28,除去他本身28外,其余5个数相加,1+2+4+7+14=28。
代码如下
???案例三:无穷的完美数序列在案例二的基础上,实现一个无穷的完美数steam
代码如下
???案例四:策略模式以策略模式为例来展开函数式编程是如何解决问题的。
策略模式包含三部分:
??一个代表某个算法的接口 ?一个或多个接口的具体实现,他们代表了算法的多种实现方式 ?一个或多个使用策略对象的客户 ?代码如下
1、算法接口
???2、具体实现
??????3、使用策略对象和函数式区别