1
0
mirror of https://github.com/duke-git/lancet.git synced 2026-03-01 00:35:28 +08:00

feat: add ReduceRight

This commit is contained in:
dudaodong
2023-04-04 17:54:54 +08:00
parent f198191063
commit c01c9d14b4
5 changed files with 95 additions and 3 deletions
+31 -1
View File
@@ -64,6 +64,7 @@ import (
- [Reverse](#Reverse) - [Reverse](#Reverse)
- [Reduce](#Reduce) - [Reduce](#Reduce)
- [ReduceBy](#ReduceBy) - [ReduceBy](#ReduceBy)
- [ReduceRight](#ReduceRight)
- [Replace](#Replace) - [Replace](#Replace)
- [ReplaceAll](#ReplaceAll) - [ReplaceAll](#ReplaceAll)
- [Repeat](#Repeat) - [Repeat](#Repeat)
@@ -1505,7 +1506,6 @@ func main() {
} }
``` ```
### <span id="ReduceBy">ReduceBy</span> ### <span id="ReduceBy">ReduceBy</span>
<p>Produces a value from slice by accumulating the result of each element as passed through the reducer function.</p> <p>Produces a value from slice by accumulating the result of each element as passed through the reducer function.</p>
@@ -1542,6 +1542,36 @@ func main() {
} }
``` ```
### <span id="ReduceRight">ReduceRight</span>
<p>ReduceRight is like ReduceBy, but it iterates over elements of slice from right to left.</p>
<b>Signature:</b>
```go
func ReduceRight[T any, U any](slice []T, initial U, reducer func(index int, item T, agg U) U) U
```
<b>Example:</b>
```go
import (
"fmt"
"github.com/duke-git/lancet/v2/slice"
)
func main() {
result := slice.ReduceRight([]int{1, 2, 3, 4}, "", func(_ int, item int, agg string) string {
return agg + fmt.Sprintf("%v", item)
})
fmt.Println(result)
// Output:
// 4321
}
```
### <span id="Replace">Replace</span> ### <span id="Replace">Replace</span>
<p>Returns a copy of the slice with the first n non-overlapping instances of old replaced by new.</p> <p>Returns a copy of the slice with the first n non-overlapping instances of old replaced by new.</p>
+30 -1
View File
@@ -64,6 +64,7 @@ import (
- [Reverse](#Reverse) - [Reverse](#Reverse)
- [Reduce](#Reduce) - [Reduce](#Reduce)
- [ReduceBy](#ReduceBy) - [ReduceBy](#ReduceBy)
- [ReduceRight](#ReduceRight)
- [Replace](#Replace) - [Replace](#Replace)
- [ReplaceAll](#ReplaceAll) - [ReplaceAll](#ReplaceAll)
- [Repeat](#Repeat) - [Repeat](#Repeat)
@@ -1506,7 +1507,6 @@ func main() {
} }
``` ```
### <span id="ReduceBy">ReduceBy</span> ### <span id="ReduceBy">ReduceBy</span>
<p>对切片中执行reduce操作。</p> <p>对切片中执行reduce操作。</p>
@@ -1543,6 +1543,35 @@ func main() {
} }
``` ```
### <span id="ReduceRight">ReduceRight</span>
<p>类似ReduceBy操作,迭代切片元素顺序从右至左。</p>
<b>函数签名:</b>
```go
func ReduceRight[T any, U any](slice []T, initial U, reducer func(index int, item T, agg U) U) U
```
<b>示例:</b>
```go
import (
"fmt"
"github.com/duke-git/lancet/v2/slice"
)
func main() {
result := slice.ReduceRight([]int{1, 2, 3, 4}, "", func(_ int, item int, agg string) string {
return agg + fmt.Sprintf("%v", item)
})
fmt.Println(result)
// Output:
// 4321
}
```
### <span id="Replace">Replace</span> ### <span id="Replace">Replace</span>
+12
View File
@@ -504,6 +504,18 @@ func ReduceBy[T any, U any](slice []T, initial U, reducer func(index int, item T
return accumulator return accumulator
} }
// ReduceRight is like ReduceBy, but it iterates over elements of slice from right to left.
// Play: todo
func ReduceRight[T any, U any](slice []T, initial U, reducer func(index int, item T, agg U) U) U {
accumulator := initial
for i := len(slice) - 1; i >= 0; i-- {
accumulator = reducer(i, slice[i], accumulator)
}
return accumulator
}
// Replace returns a copy of the slice with the first n non-overlapping instances of old replaced by new. // Replace returns a copy of the slice with the first n non-overlapping instances of old replaced by new.
// Play: https://go.dev/play/p/P5mZp7IhOFo // Play: https://go.dev/play/p/P5mZp7IhOFo
func Replace[T comparable](slice []T, old T, new T, n int) []T { func Replace[T comparable](slice []T, old T, new T, n int) []T {
+11
View File
@@ -477,6 +477,17 @@ func ExampleReduceBy() {
// 1234 // 1234
} }
func ExampleReduceRight() {
result := ReduceRight([]int{1, 2, 3, 4}, "", func(_ int, item int, agg string) string {
return agg + fmt.Sprintf("%v", item)
})
fmt.Println(result)
// Output:
// 4321
}
func ExampleReplace() { func ExampleReplace() {
strs := []string{"a", "b", "c", "a"} strs := []string{"a", "b", "c", "a"}
+11 -1
View File
@@ -406,7 +406,7 @@ func TestReduce(t *testing.T) {
} }
func TestReduceBy(t *testing.T) { func TestReduceBy(t *testing.T) {
assert := internal.NewAssert(t, "TestReduce2") assert := internal.NewAssert(t, "TestReduceBy")
result1 := ReduceBy([]int{1, 2, 3, 4}, 0, func(_ int, item int, agg int) int { result1 := ReduceBy([]int{1, 2, 3, 4}, 0, func(_ int, item int, agg int) int {
return agg + item return agg + item
@@ -421,6 +421,16 @@ func TestReduceBy(t *testing.T) {
} }
func TestReduceRight(t *testing.T) {
assert := internal.NewAssert(t, "ReduceRight")
result := ReduceRight([]int{1, 2, 3, 4}, "", func(_ int, item int, agg string) string {
return agg + fmt.Sprintf("%v", item)
})
assert.Equal("4321", result)
}
func TestIntSlice(t *testing.T) { func TestIntSlice(t *testing.T) {
var nums []any var nums []any
nums = append(nums, 1, 2, 3) nums = append(nums, 1, 2, 3)