Решение на Poor Man's Currying от Божин Кацарски

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

Към профила на Божин Кацарски

Резултати

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

Код

package main
func Repeater(s, sep string) func(int) string {
return func(times int) string {
res := ""
for i := 0; i < times; i++ {
if i > 0 {
res += sep
}
res += s
}
return res
}
}
func Generator(next func(int) int, current int) func() int {
return func() (result int) {
result = current
current = next(current)
return
}
}
func MapReducer(
mapper func(int) int,
reducer func(int, int) int,
initial int) func(...int) int {
return func(args ...int) int {
result := initial
for _, val := range args {
result = reducer(result, mapper(val))
}
return result
}
}

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

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

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

Божин обнови решението на 18.10.2018 23:19 (преди 10 месеца)

+package main
+
+func Repeater(s, sep string) func(int) string {
+ return func(times int) string {
+ res := ""
+ for i := 0; i < times; i++ {
+ if i > 0 {
+ res += sep
+ }
+ res += s
+ }
+ return res
+ }
+}
+
+func Generator(next func(int) int, current int) func() int {
+ return func() (result int) {
+ result = current
+ current = next(current)
+ return
+ }
+}
+
+func MapReducer(
+ mapper func(int) int,
+ reducer func(int, int) int,
+ initial int) func(...int) int {
+
+ return func(args ...int) int {
+ result := initial
+
+ for _, val := range args {
+ result = reducer(result, mapper(val))
+ }
+
+ return result
+ }
+}