Решение на Poor Man's Currying от Красена Давидова

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

Към профила на Красена Давидова

Резултати

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

Код

package main
func Repeater(s, sep string) func(int) string {
return func(x int) string {
res := ""
if x <= 0 {
return res
}
for i := 0; i < x-1; i++ {
res = res + s + sep
}
res = res + s
return res
}
}
func Generator(gen func(int) int, initial int) func() int {
return func() int {
next := initial
initial = gen(next)
return next
}
}
func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
return func(arr ...int) int {
res := initial
for _, val := range arr {
res = reducer(res, mapper(val))
}
return res
}
}

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

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

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

Красена обнови решението на 20.10.2018 16:39 (преди 10 месеца)

+package main
+
+func Repeater(s, sep string) func(int) string {
+ return func(x int) string {
+ res := ""
+ if x <= 0 {
+ return res
+ }
+ for i := 0; i < x-1; i++ {
+ res = res + s + sep
+ }
+ res = res + s
+ return res
+ }
+}
+
+func Generator(gen func(int) int, initial int) func() int {
+ return func() int {
+ next := initial
+ initial = gen(next)
+ return next
+ }
+}
+
+func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
+ return func(arr ...int) int {
+ res := initial
+ for _, val := range arr {
+ res = reducer(res, mapper(val))
+ }
+ return res
+ }
+}