Решение на Poor Man's Currying от Doychin Atanasov

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

Към профила на Doychin Atanasov

Резултати

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

Код

package main
import (
"strings"
)
func Repeater(s, sep string) func(int) string {
return func(n int) string {
return strings.TrimSuffix(strings.Repeat(s+sep, n), sep)
}
}
func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
return func(args ...int) int {
acc := initial
for i := 0; i < len(args); i++ {
acc = reducer(acc, mapper(args[i]))
}
return acc
}
}
func Generator(gen func(int) int, initial int) func() int {
next := initial
return func() int {
current := next
next = gen(current)
return current
}
}

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

PASS
ok  	_/tmp/d20181024-53-1ww1lsn	0.002s
PASS
ok  	_/tmp/d20181024-53-1ww1lsn	0.003s
PASS
ok  	_/tmp/d20181024-53-1ww1lsn	0.002s
PASS
ok  	_/tmp/d20181024-53-1ww1lsn	0.002s
PASS
ok  	_/tmp/d20181024-53-1ww1lsn	0.002s
PASS
ok  	_/tmp/d20181024-53-1ww1lsn	0.002s

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

Doychin обнови решението на 17.10.2018 23:20 (преди 10 месеца)

+package main
+
+import (
+ "strings"
+)
+
+func Repeater(s, sep string) func(int) string {
+ return func(n int) string {
+ return strings.TrimSuffix(strings.Repeat(s+sep, n), sep)
+ }
+}
+
+func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
+ return func(args ...int) int {
+ acc := initial
+ for i := 0; i < len(args); i++ {
+ acc = reducer(acc, mapper(args[i]))
+ }
+ return acc
+ }
+}
+
+func Generator(gen func(int) int, initial int) func() int {
+ next := initial
+ return func() int {
+ current := next
+ next = gen(current)
+ return current
+ }
+}