Решение на Poor Man's Currying от Слави Боянов

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

Към профила на Слави Боянов

Резултати

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

Код

package main
func Repeater(
toRepeate string,
separator string,
) func(int) string {
return func(times int) (result string) {
if times > 0 {
for i := 1; i < times; i++ {
result += toRepeate + separator
}
result += toRepeate
}
return
}
}
func Generator(
genFunction func(int) int,
current int,
) func() int {
return func() (result int) {
result = current
current = genFunction(current)
return
}
}
func MapReducer(
mapper func(int) int,
reducer func(int, int) int,
initial int,
) func(...int) int {
return func(values ...int) (result int) {
result = initial
for _, value := range values {
result = reducer(result, mapper(value))
}
return
}
}

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

PASS
ok  	_/tmp/d20181024-53-19oki7y	0.002s
PASS
ok  	_/tmp/d20181024-53-19oki7y	0.002s
PASS
ok  	_/tmp/d20181024-53-19oki7y	0.002s
PASS
ok  	_/tmp/d20181024-53-19oki7y	0.002s
PASS
ok  	_/tmp/d20181024-53-19oki7y	0.003s
PASS
ok  	_/tmp/d20181024-53-19oki7y	0.002s

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

Слави обнови решението на 20.10.2018 23:33 (преди 10 месеца)

+package main
+
+func Repeater(
+ toRepeate string,
+ separator string,
+) func(int) string {
+ return func(times int) (result string) {
+ if times > 0 {
+ for i := 1; i < times; i++ {
+ result += toRepeate + separator
+ }
+ result += toRepeate
+ }
+ return
+ }
+}
+
+func Generator(
+ genFunction func(int) int,
+ current int,
+) func() int {
+ return func() (result int) {
+ result = current
+ current = genFunction(current)
+ return
+ }
+}
+
+func MapReducer(
+ mapper func(int) int,
+ reducer func(int, int) int,
+ initial int,
+) func(...int) int {
+ return func(values ...int) (result int) {
+ result = initial
+ for _, value := range values {
+ result = reducer(result, mapper(value))
+ }
+ return
+ }
+}