Решение на Poor Man's Currying от Янислав Василев

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

Към профила на Янислав Василев

Резултати

  • 8 точки от тестове
  • 1 бонус точка
  • 9 точки общо
  • 5 успешни тест(а)
  • 1 неуспешни тест(а)

Код

package main
import (
"strings"
)
func Repeater(s, sep string) func(int) string {
var sb strings.Builder
return func(times int) string {
for i := 0; i < times; i++ {
sb.WriteString(s)
if i != times-1 {
sb.WriteString(sep)
}
}
return sb.String()
}
}
func Generator(gen func(int) int, initial int) func() int {
previous := initial
return func() int {
defer func() { previous = gen(previous) }()
return previous
}
}
func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
return func(args ...int) int {
mapped := make([]int, len(args))
for index, number := range args {
mapped[index] = mapper(number)
}
accumulation := initial
for i := 0; i < len(mapped); i++ {
accumulation = reducer(accumulation, mapped[i])
}
return accumulation
}
}
func main() {
}

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

PASS
ok  	_/tmp/d20181024-53-372gvs	0.002s
PASS
ok  	_/tmp/d20181024-53-372gvs	0.002s
--- FAIL: TestRepeaterMultipleCalls (0.00s)
    solution_test.go:147: Expected `gopher,gopher,gopher` but got `gopher,gopher,gophergopher,gopher,gopher` after 2nd call
FAIL
exit status 1
FAIL	_/tmp/d20181024-53-372gvs	0.002s
PASS
ok  	_/tmp/d20181024-53-372gvs	0.002s
PASS
ok  	_/tmp/d20181024-53-372gvs	0.002s
PASS
ok  	_/tmp/d20181024-53-372gvs	0.002s

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

Янислав обнови решението на 24.10.2018 16:14 (преди 10 месеца)

+package main
+
+import (
+ "strings"
+)
+
+func Repeater(s, sep string) func(int) string {
+ var sb strings.Builder
+
+ return func(times int) string {
+ for i := 0; i < times; i++ {
+ sb.WriteString(s)
+
+ if i != times-1 {
+ sb.WriteString(sep)
+ }
+ }
+
+ return sb.String()
+ }
+}
+
+func Generator(gen func(int) int, initial int) func() int {
+ previous := initial
+
+ return func() int {
+ defer func() { previous = gen(previous) }()
+ return previous
+ }
+}
+
+func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
+ return func(args ...int) int {
+ mapped := make([]int, len(args))
+ for index, number := range args {
+ mapped[index] = mapper(number)
+ }
+
+ accumulation := initial
+ for i := 0; i < len(mapped); i++ {
+ accumulation = reducer(accumulation, mapped[i])
+ }
+
+ return accumulation
+ }
+}
+
+func main() {
+
+}

Мда, видях по коментарите от другите решения, попринцип хората казват, че пише някъде в гайда, че не трябва да има main функция ама аз явно съм сляп и не мога да го видя о.О