mirror of
https://github.com/crazybber/awesome-patterns.git
synced 2024-11-22 04:36:02 +03:00
cache added
This commit is contained in:
parent
135ae1e4e1
commit
9ce988f0e6
@ -2,17 +2,37 @@ package main
|
||||
|
||||
import "fmt"
|
||||
|
||||
func Fibonacci(x int) int {
|
||||
type Memoized func(int) int
|
||||
|
||||
var fibMem = Memoize(fib)
|
||||
|
||||
func Memoize(mf Memoized) Memoized {
|
||||
cache := make(map[int]int)
|
||||
return func(key int) int {
|
||||
if val, found := cache[key]; found {
|
||||
return val
|
||||
}
|
||||
temp := mf(key)
|
||||
cache[key] = temp
|
||||
return temp
|
||||
}
|
||||
}
|
||||
|
||||
func FibMemoized(n int) int {
|
||||
return fibMem(n)
|
||||
}
|
||||
|
||||
func fib(x int) int {
|
||||
if x == 0 {
|
||||
return 0
|
||||
} else if x <= 2 {
|
||||
return 1
|
||||
} else {
|
||||
return Fibonacci(x-2) + Fibonacci(x-1)
|
||||
return fib(x-2) + fib(x-1)
|
||||
}
|
||||
}
|
||||
|
||||
func main() {
|
||||
fib := Fibonacci
|
||||
fmt.Printf("%vn", fib(50))
|
||||
fmt.Println(fib(30))
|
||||
fmt.Println(FibMemoized(30))
|
||||
}
|
||||
|
1
functional_programming/ch01/memoized.go
Normal file
1
functional_programming/ch01/memoized.go
Normal file
@ -0,0 +1 @@
|
||||
package main
|
Loading…
Reference in New Issue
Block a user