Решение на Poor Man's Currying от Димитър Дулев

Обратно към всички решения

Към профила на Димитър Дулев

Резултати

  • 10 точки от тестове
  • 0 бонус точки
  • 10 точки общо
  • 6 успешни тест(а)
  • 0 неуспешни тест(а)

Код

package main
func Repeater(s, sep string) func(int) string {
var repeater func(n int) string
repeater = func(n int) string {
if n < 1 {
return ""
}
if n == 1 {
return s
}
return s + sep + repeater(n-1)
}
return repeater
}
func Generator(gen func(int) int, initial int) func() int {
current := initial
return func() int {
defer func() {
current = gen(current)
}()
return current
}
}
func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
return func(array ...int) int {
current := initial
for _, v := range array {
current = reducer(current, mapper(v))
}
return current
}
}

Лог от изпълнението

PASS
ok  	_/tmp/d20181024-53-gz24sx	0.002s
PASS
ok  	_/tmp/d20181024-53-gz24sx	0.002s
PASS
ok  	_/tmp/d20181024-53-gz24sx	0.002s
PASS
ok  	_/tmp/d20181024-53-gz24sx	0.002s
PASS
ok  	_/tmp/d20181024-53-gz24sx	0.002s
PASS
ok  	_/tmp/d20181024-53-gz24sx	0.002s

История (1 версия и 2 коментара)

Димитър обнови решението на 23.10.2018 13:14 (преди 10 месеца)

+package main
+
+func Repeater(s, sep string) func(int) string {
+ var repeater func(n int) string
+ repeater = func(n int) string {
+ if n < 1 {
+ return ""
+ }
+ if n == 1 {
+ return s
+ }
+ return s + sep + repeater(n-1)
+ }
+ return repeater
+}
+
+func Generator(gen func(int) int, initial int) func() int {
+ current := initial
+ return func() int {
+ defer func() {
+ current = gen(current)
+ }()
+ return current
+ }
+}
+
+func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
+ return func(array ...int) int {
+ current := initial
+ for _, v := range array {
+ current = reducer(current, mapper(v))
+ }
+ return current
+ }
+}