-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path053_reduce.go
63 lines (60 loc) · 1.08 KB
/
053_reduce.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
package main
import R "reflect"
func Reduce[T any](c any, f func(T, T) T) (r T) {
switch c := c.(type) {
case interface{ Range(f func(int, T)) }:
c.Range(func(i int, v T) {
r = f(r, v)
})
case interface{ Reduce(func(T, T) T) T }:
r = c.Reduce(f)
case string:
for _, x := range c {
r = f(r, any(x).(T))
}
case T:
r = f(r, c)
case []T:
for _, x := range c {
r = f(r, x)
}
case map[int]T:
for _, x := range c {
r = f(r, x)
}
case func(int) (T, bool):
for i := 0; ; i++ {
if v, ok := c(i); ok {
r = f(r, v)
} else {
break
}
}
case chan T:
for x := range c {
r = f(r, x)
}
default:
switch c := R.ValueOf(c); c.Kind() {
case R.Map:
for i := c.MapRange(); i.Next(); {
r = f(r, i.Value().Interface().(T))
}
case R.Array:
for i := 0; i < c.Len(); i++ {
r = f(r, c.Index(i).Interface().(T))
}
case R.Func:
for i := 0; ; i++ {
p := []R.Value{R.ValueOf(i)}
if p = c.Call(p); p[1].Interface() == true {
r = f(r, p[0].Interface().(T))
} else {
break
}
}
}
}
return
}
func main() {}