Skip to content

Instantly share code, notes, and snippets.

@c-yan
Created February 14, 2018 15:09
Show Gist options
  • Save c-yan/d8e64ffab357555db66091a9d17d9c89 to your computer and use it in GitHub Desktop.
Save c-yan/d8e64ffab357555db66091a9d17d9c89 to your computer and use it in GitHub Desktop.
package main
import (
"fmt"
)
func main() {
memoizedFactorial := func() func(int) int {
cache := make(map[int]int)
var factorial func(n int) int
factorial = func(n int) int {
v, ok := cache[n]
if ok {
return v
}
fmt.Printf("call factorial: %d\n", n)
if n == 1 {
return 1
} else {
cache[n] = n * factorial(n-1)
return cache[n]
}
}
return factorial
}
factorial := memoizedFactorial()
fmt.Println(factorial(4))
fmt.Println(factorial(6))
}
@c-yan
Copy link
Author

c-yan commented Feb 14, 2018

execution result

>self-memoized-factorial.exe
call factorial: 4
call factorial: 3
call factorial: 2
call factorial: 1
24
call factorial: 6
call factorial: 5
720

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment