underscore/sliding.go
Ruidy 85f73f63a9
feat: add Sliding window function (#47)
- Add Sliding: creates sliding window views of a slice
- Pre-allocated for optimal performance
- Returns independent window copies (non-mutating)
- Comprehensive tests including edge cases
- Benchmark included

Example: Sliding([1,2,3,4,5], 3) → [[1,2,3], [2,3,4], [3,4,5]]

Resolves Issue 19

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-authored-by: Claude <noreply@anthropic.com>
2025-11-16 08:54:29 +01:00

23 lines
646 B
Go

package underscore
// Sliding creates a sliding window view of the slice with the specified window size.
// Returns an empty slice if size is less than or equal to 0.
// Returns an empty slice if size is greater than the slice length.
//
// Example: Sliding([]int{1,2,3,4,5}, 3) → [[1,2,3], [2,3,4], [3,4,5]]
func Sliding[T any](values []T, size int) [][]T {
if size <= 0 || size > len(values) {
return [][]T{}
}
windowCount := len(values) - size + 1
res := make([][]T, 0, windowCount)
for i := 0; i <= len(values)-size; i++ {
window := make([]T, size)
copy(window, values[i:i+size])
res = append(res, window)
}
return res
}