98 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // For more tutorials: https://blog.learngoprogramming.com
 | |
| //
 | |
| // Copyright © 2018 Inanc Gumus
 | |
| // Learn Go Programming Course
 | |
| // License: https://creativecommons.org/licenses/by-nc-sa/4.0/
 | |
| //
 | |
| 
 | |
| package main
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| )
 | |
| 
 | |
| type filterFunc func(int) bool
 | |
| 
 | |
| func main() {
 | |
| 	fmt.Println("••• HIGHER-ORDER FUNCS •••")
 | |
| 
 | |
| 	nums := []int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
 | |
| 
 | |
| 	odd := reverse(reverse(isEven))
 | |
| 	fmt.Printf("reversed   : %t\n", odd(8))
 | |
| 
 | |
| 	fmt.Printf("> 3        : %d\n", filter(greater(3), nums...))
 | |
| 	fmt.Printf("> 6        : %d\n", filter(greater(6), nums...))
 | |
| 	fmt.Printf("<= 6       : %d\n", filter(lesseq(6), nums...))
 | |
| 	fmt.Printf("<= 6       : %d\n", filter(reverse(greater(6)), nums...))
 | |
| 
 | |
| 	fmt.Println("\n••• CLOSURES •••")
 | |
| 	fmt.Printf("uniques    : %d\n", filter(uniques(), 1, 1, 2, 3, 3))
 | |
| 
 | |
| 	dups := reverse(uniques())
 | |
| 	fmt.Printf("dups       : %v\n", filter(dups, 1, 1, 2, 3, 3))
 | |
| 
 | |
| 	dups = reverse(uniques())
 | |
| 	fmt.Printf("dups dups  : %v\n", filter(dups, 1, 1, 2, 3, 3, 3, 3))
 | |
| 
 | |
| 	dups = reverse(uniques())
 | |
| 	out := filter(dups, 1, 1, 2, 3, 3, 3, 3)
 | |
| 	fmt.Printf("dups uniqs : %v\n", filter(uniques(), out...))
 | |
| 
 | |
| 	dups = reverse(uniques())
 | |
| 	chained := chain(reverse(greater(1)), dups, uniques())
 | |
| 	fmt.Printf("dups chain : %v\n", filter(chained, 1, 1, 2, 3, 3, 3, 3, 0, 0))
 | |
| }
 | |
| 
 | |
| func chain(filters ...filterFunc) filterFunc {
 | |
| 	return func(n int) bool {
 | |
| 		for _, next := range filters {
 | |
| 			if !next(n) {
 | |
| 				return false
 | |
| 			}
 | |
| 		}
 | |
| 		return true
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func uniques() filterFunc {
 | |
| 	seen := make(map[int]bool)
 | |
| 
 | |
| 	return func(n int) (ok bool) {
 | |
| 		if !seen[n] {
 | |
| 			seen[n], ok = true, true
 | |
| 		}
 | |
| 		return
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func reverse(f filterFunc) filterFunc {
 | |
| 	return func(n int) bool {
 | |
| 		return !f(n)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func greater(min int) filterFunc {
 | |
| 	return func(n int) bool {
 | |
| 		return n > min
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func lesseq(max int) filterFunc {
 | |
| 	return func(n int) bool {
 | |
| 		return n <= max
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func filter(f filterFunc, nums ...int) (filtered []int) {
 | |
| 	for _, n := range nums {
 | |
| 		if f(n) {
 | |
| 			filtered = append(filtered, n)
 | |
| 		}
 | |
| 	}
 | |
| 	return
 | |
| }
 | |
| 
 | |
| func isEven(n int) bool { return n%2 == 0 }
 | |
| func isOdd(m int) bool  { return m%2 == 1 }
 |