Решение на Poor Man's Currying от Димитър Петров

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

Към профила на Димитър Петров

Резултати

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

Код

package main
func Repeater(s, sep string) func(int) string {
return func(n int) string {
result := ""
if n < 1 {
return result
}
for i := 0; i < n-1; i++ {
result += s
result += sep
}
return result + s
}
}
func Generator(gen func(int) int, initial int) func() int {
last := initial
return func() int {
defer func() { last = gen(last) }()
return last
}
}
func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
return func(args ...int) int {
result := initial
for _, v := range args {
result = reducer(result, mapper(v))
}
return result
}
}

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

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

История (3 версии и 2 коментара)

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

+package main
+
+func Repeater(s, sep string) func(int) string {
+ return func(n int) string {
+ result := ""
+ for i := 0; i < n-1; i++ {
+ result += s
+ result += sep
+ }
+ return result + s
+ }
+}
+
+func Generator(gen func(int) int, initial int) func() int {
+ last := initial
+ return func() int {
+ defer func() { last = gen(last) }()
+ return last
+ }
+}
+
+func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
+ return func(args ...int) int {
+ for i, v := range args {
+ args[i] = mapper(v)
+ }
+ result := initial
+ for _, v := range args {
+ result = reducer(result, v)
+ }
+ return result
+ }
+}

Димитър обнови решението на 21.10.2018 18:38 (преди 10 месеца)

package main
func Repeater(s, sep string) func(int) string {
return func(n int) string {
result := ""
+ if n < 1 {
+ return result
+ }
for i := 0; i < n-1; i++ {
result += s
result += sep
}
return result + s
}
}
func Generator(gen func(int) int, initial int) func() int {
last := initial
return func() int {
defer func() { last = gen(last) }()
return last
}
}
func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
return func(args ...int) int {
for i, v := range args {
args[i] = mapper(v)

Не мисля, че е добре да променяш входните си аргументи. Още не сме предали в подробности за slices, но за теб ще направя лична лекция в този коментар :D Слайсовете са структура, която всъщност "сочи" към реален масив паметта. Когато подаваш слайс като аргумент, то копираш само тази структура, а не целия масив. Тоест в твоя случай променяш реалния масив, който ти е подаден като аргумент. Може да видиш и този блог пост: https://blog.golang.org/go-slices-usage-and-internals

Благодаря за обратната връзка, нaистина в случая в който се подава слайс дефиниран някъде другаде а не произволен брой int-ове, конструкцията не си заделя нов масив, а променя реалният към който сочи слайс-а.

}
result := initial
for _, v := range args {
result = reducer(result, v)
}
return result
}
}

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

package main
func Repeater(s, sep string) func(int) string {
return func(n int) string {
result := ""
if n < 1 {
return result
}
for i := 0; i < n-1; i++ {
result += s
result += sep
}
return result + s
}
}
func Generator(gen func(int) int, initial int) func() int {
last := initial
return func() int {
defer func() { last = gen(last) }()
return last
}
}
func MapReducer(mapper func(int) int, reducer func(int, int) int, initial int) func(...int) int {
return func(args ...int) int {
- for i, v := range args {
- args[i] = mapper(v)
- }
result := initial
for _, v := range args {
- result = reducer(result, v)
+ result = reducer(result, mapper(v))
}
return result
}
}