115 Decks Ordered By Applause Count - Highest First - Chse one - invert order

# Title Applauses  
1 Monad Laws Must Be Checked 244  
2 N-Queens Combinatorial Puzzle meets Cats 133  
3 Direct Style Effect Systems - The Print[A] Example - A Comprehension Aid 121  
4 Definitions of Functional Programming 104  
5 N-Queens Combinatorial Problem - Polyglot FP for Fun and Profit – Haskell and Scala - Part 1 104  
6 The Functional Programming Triad of map, filter and fold 99  
7 The Sieve of Eratosthenes - Part 2 - Genuine versus Unfaithful Sieve 94  
8 Nat, List and Option Monoids - From scratch - Combining and Folding - An example 92  
9 Scala Left Fold Parallelisation - Three Approaches 91  
10 From Scala Monadic Effects to Unison Algebraic Effects 90  
11 The Debt Metaphor - Ward Cunningham in his 2009 YouTube video 87  
12 Functional Core and Imperative Shell - Game of Life Example - Haskell and Scala 83  
13 Folding Cheat Sheet #1 - Folding over recursively defined data structures for natural numbers and lists 81  
14 Hand Rolled Applicative User Validation Code Kata 80  
15 Tagless Final Encoding - Algebras and Interpreters and also Programs 76  
16 The Functional Programming Triad of Folding, Scanning and Iteration - A first example in Scala and Haskell 76  
17 Scala 3 enum for a terser Option Monad Algebraic Data Type 75  
18 Computer Graphics in Java and Scala - Part 1b 70  
19 Drawing Heighway’s Dragon - Part 1 - Recursive Function Rewrite - From Imperative Style in Pascal 64 To Functional Style in Scala 3 69  
20 Compositionality and Category Theory 66  
21 From Subtype Polymorphism To Typeclass-based Ad hoc Polymorphism - An Example 66  
22 Folding Cheat Sheet #4 - For functions that can be defined both as a right fold and as a left fold, one may be more efficient than the other 66  
23 Refactoring: A First Example - Martin Fowler’s First Example of Refactoring, Adapted to Java 65  
24 A Sighting of filterA in Typelevel Rite of Passage 65  
25 Refactoring: A First Example - Martin Fowler’s First Example of Refactoring, Adapted to Scala 64  
26 Folding Cheat Sheet #6 - Left and right folds and tail recursion 62  
27 Folding Unfolded - Part 2 61  
28 Function Applicative for Great Good of Leap Year Function 61  
29 Computer Graphics in Java and Scala - Part 1 61  
30 Quicksort - a whistle-stop tour of the algorithm in five languages and four paradigms 60  
31 Applicative Functor - Part 2 60  
32 Game of Life - Polyglot FP - Haskell and Scala - Part 3 58  
33 N-Queens Combinatorial Problem - Polyglot FP for Fun and Profit – Haskell and Scala - Part 3 58  
34 Monad Fact #3 58  
35 Folding Unfolded - Part 3 58  
36 Folding Cheat Sheet #2 - Programmatic and mathematical definitions of right fold and left fold 57  
37 Applicative Functor - Part 1 57  
38 Monoids - Part 1 - With examples using Scalaz and Cats 57  
39 Kleisli composition, flatMap, join, map, unit - implementation and interrelation - V2 updated for Scala 3 56  
40 Game of Life - Polyglot FP - Haskell and Scala - Part 1 55  
41 Monad Fact #1 55  
42 Lambda Expressions and Java 8 - Lambda Calculus, Lambda Expressions, Syntactic Sugar, First Class Functions 54  
43 N-Queens Combinatorial Problem - Polyglot FP for Fun and Profit – Haskell and Scala - Part 4 54  
44 Monad Fact #4 53  
45 The Uniform Access Principle 53  
46 Folding Unfolded - Part 1 53  
47 Scala 3 by Example - Algebraic Data Types for Domain Driven Design - Part 1 53  
48 State Monad 52  
49 Arrive at monads by going from composition of pure functions to composition of effectful functions 52  
50 Functor Laws 52  
51 Folding Cheat Sheet #3 - The universal property of fold 52  
52 Algebraic Data Types for Data Oriented Programming - From Haskell and Scala to Java 52  
53 Sum and Product Types - The Fruit Salad & Fruit Snack Example 52  
54 Folding Unfolded - Part 4 51  
55 Kleisli Composition 51  
56 N-Queens Combinatorial Problem - Polyglot FP for Fun and Profit – Haskell and Scala - Part 2 51  
57 The Monad Fact Series 51  
58 Monad Fact #6 51  
59 Writer Monad for logging execution of functions 50  
60 Function Applicative for Great Good of Palindrome Checker Function 50  
61 Left and Right Folds - Comparison of a mathematical definition and a programmatic one 49  
62 Natural Transformations 48  
63 Monad Fact #2 48  
64 Applicative Functor - Part 3 48  
65 A sighting of traverse_ in Practical FP in Scala 47  
66 The Expression Problem Part 2 47  
67 The Sieve of Eratosthenes - Part 1 46  
68 Game of Life - Polyglot FP - Haskell and Scala - Part 2 46  
69 Fusing Transformations of Strict Scala Collections with Views 46  
70 The aggregate function - from sequential and parallel folds to parallel aggregation 45  
71 The Expression Problem Part 1 45  
72 Folding Cheat Sheet #7 - The three duality theorems of fold 45  
73 Monad Fact #5 44  
74 Sierpinski Triangle - Polyglot FP for Fun and Profit - Haskell and Scala 44  
75 Side by Side - Scala and Java Adaptations of Martin Fowler’s Javascript Refactoring Example 44  
76 Monoids - Part 2 - With examples using Scalaz and Cats 44  
77 A sighting of traverseFilter and foldMap in Practical FP in Scala 44  
78 Folding Cheat Sheet #8 - Folding with monoids 43  
79 ‘go-to’ general-purpose sequential collections - from Java To Scala 42  
80 Folding Unfolded - Part 5 42  
81 Folding Cheat Sheet #5 - Folding a list right and left using Cons and Nil results in the identity and reverse functions 41  
82 Functional Effects - Part 2 41  
83 Functional Effects - Part 1 41  
84 Sequence and Traverse - Part 2 41  
85 Ad hoc Polymorphism using Type Classes and Cats 40  
86 Folding Cheat Sheet Series Titles 40  
87 A sighting of sequence function in Practical FP in Scala 39  
88 Sequence and Traverse - Part 1 39  
89 Monad Transformers - Part 1 38  
90 Sequence and Traverse - Part 3 38  
91 Monads do not Compose 36  
92 Fibonacci Function Gallery - Part 1 34  
93 Scala 3 by Example - Algebraic Data Types for Domain Driven Design - Part 2 33  
94 Fibonacci Function Gallery - Part 2 33  
95 Folding Cheat Sheet #9 - List Unfolding - 'unfold' as the Computational Dual of 'fold', and how 'unfold' relates to 'iterate' 32  
96 Symmetry in the interrelation of flatMap/foldMap/traverse and flatten/fold/sequence 31  
97 Functor Composition 31  
98 Function Composition - forward composition versus backward composition 30  
99 Addendum to `Monads do not Compose` 29  
100 The Open-Closed Principle - Part 1 - The Original Version 29  
101 Drawing Heighway’s Dragon - Part 2 - Recursive Function Simplification - From 2^n Recursive Invocations To n Tail-Recursive Invocations Exploiting Self-Similarity 28  
102 Year when lambda functions were introduced in various languages 28  
103 Monad as Functor with pair of Natural Transformations 27  
104 Drawing Heighway’s Dragon - Part 4 - Interactive and Animated Dragon Creation 26  
105 De Morgan's Laws are Monoid Homomorphisms 25  
106 The Nature of Complexity in John Ousterhout’s Philosophy of Software Design 25  
107 List Unfolding - 'unfold' as the Computational Dual of 'fold', and how 'unfold' relates to 'iterate' 24  
108 The Open-Closed Principle - Part 2 - The Contemporary Version - An Introduction 23  
109 Drawing Heighway’s Dragon - Part 3 - Simplification Through Separation of Concerns - Rotation Without Matrix Multiplication 21  
110 Test Doubles - Terminology, Definitions and Illustrations - with Examples - Part 1 21  
111 Non-strict functions, bottom, and Scala by-name parameters 19  
112 Point-free or Die - Tacit Programming in Haskell 16  
113 ApplicativeError functions handling and recovering from errors: A mnemonic to recall their signatures from their names 11  
114 Combinatorial Interview Problems with Backtracking Solutions - from Procedural to Functional Programming - Part 1 9  
115 Combinatorial Interview Problems with Backtracking Solutions - from Procedural to Functional Programming - Part 2 2