Documentation ¶
Index ¶
- func Sort[T any](S []T, sf SortFunc[T], isAsc bool)
- func StableSort[T any](S []T, sf SortFunc[T], isAsc bool)
- type Bucket
- type BucketSet
- type ErrNotComparable
- type Slice
- func (s *Slice[T]) Difference(other *Slice[T]) *Slice[T]
- func (s *Slice[T]) Find(elem T) int
- func (s *Slice[T]) FindSubsliceFrom(other *Slice[T], at int) int
- func (s *Slice[T]) IndexOfDuplicate() int
- func (s *Slice[T]) Insert(elem T, force bool) int
- func (s *Slice[T]) MergeUnique(other *Slice[T]) *Slice[T]
- func (s *Slice[T]) TryInsert(elem T) (int, bool)
- func (s *Slice[T]) Uniquefy()
- type SortFunc
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Sort ¶ added in v0.3.20
Sort is a function that sorts a slice of elements in ascending order.
Parameters:
- slice: The slice to sort.
- sf: A function that compares two elements.
- isAsc: A flag indicating if the sort is in ascending order.
Behaviors:
- This function uses the Quick Sort algorithm to sort the slice.
- The elements in the slice must implement the Comparer interface.
func StableSort ¶ added in v0.3.20
StableSort is a function that sorts a slice of elements in ascending order while preserving the order of equal elements.
Parameters:
- slice: The slice to sort.
- sf: A function that compares two elements.
- isAsc: A flag indicating if the sort is in ascending order.
Behaviors:
- This function uses the Merge Sort algorithm to sort the slice.
- The elements in the slice must implement the Comparer interface.
Types ¶
type Bucket ¶ added in v0.3.20
type Bucket[T any] struct { // contains filtered or unexported fields }
Bucket represents a bucket of elements.
func NewBucket ¶ added in v0.3.20
NewBucket creates a new bucket of elements.
Parameters:
- elements: elements to add to the bucket.
Returns:
- *Bucket: the new bucket.
func (*Bucket[T]) Add ¶ added in v0.3.20
func (b *Bucket[T]) Add(element T)
Add adds a element to the bucket.
Parameters:
- element: element to add.
func (*Bucket[T]) GetSize ¶ added in v0.3.20
GetSize returns the size of the bucket.
Returns:
- int: the size of the bucket.
func (*Bucket[T]) Limit ¶ added in v0.3.20
Limit limits the number of elements in the bucket.
Parameters:
- n: number of elements to keep.
Behaviors:
- If the n is less than or equal to 0, then the bucket will be empty.
- If the n is greater then the size of the bucket, then the bucket will remain the same.
func (*Bucket[T]) LinearKeep ¶ added in v0.3.20
func (b *Bucket[T]) LinearKeep(f us.PredicateFilter[T])
LinearKeep keeps the elements in the bucket that satisfy the given predicate filter.
Parameters:
- f: predicate filter to use.
type BucketSet ¶ added in v0.3.20
type BucketSet[K comparable, E any] struct { // contains filtered or unexported fields }
BucketSet is a type that represents a set of buckets.
func NewBucketSet ¶ added in v0.3.20
func NewBucketSet[K comparable, E any](elems []E, f func(E) K) *BucketSet[K, E]
NewBucketSet creates a map of buckets from the given elements using the given function.
Parameters:
- elems: elements to add to the buckets.
- f: function to use to determine the size of the buckets.
Returns:
- map[int]*Bucket: the map of buckets.
func (*BucketSet[K, E]) KeepIfBuckets ¶ added in v0.3.20
func (bs *BucketSet[K, E]) KeepIfBuckets(f us.PredicateFilter[E])
KeepIfBuckets keeps the elements in the buckets that satisfy the given predicate filter.
Parameters:
- f: predicate filter to use.
func (*BucketSet[K, E]) Sort ¶ added in v0.3.20
Sort sorts the buckets using the given function.
Parameters:
- buckets: buckets to sort.
- sf: comparison function to use.
- isAsc: flag indicating if the sort is in ascending order.
func (*BucketSet[K, E]) ViewTopNBuckets ¶ added in v0.3.20
ViewTopNBuckets returns the top N buckets.
Parameters:
- n: number of buckets to return.
type ErrNotComparable ¶ added in v0.3.20
type ErrNotComparable[A, B any] struct { // First is the first value that is not comparable. First A // Second is the second value that is not comparable. Second B }
ErrNotComparable is an error type that is returned when two values are not comparable.
func NewErrNotComparable ¶ added in v0.3.20
func NewErrNotComparable[A, B any](first A, second B) *ErrNotComparable[A, B]
NewErrNotComparable creates a new ErrNotComparable error with the provided values.
Parameters:
- first: The first value that is not comparable.
- second: The second value that is not comparable.
Returns:
- *ErrNotComparable: A pointer to the new error.
func (*ErrNotComparable[A, B]) Error ¶ added in v0.3.20
func (e *ErrNotComparable[A, B]) Error() string
Error returns the error message: "values <First> and <Second> are not comparable".
Returns:
- string: The error message.
type Slice ¶
type Slice[T any] struct { // contains filtered or unexported fields }
Slice is a slice that uses the Compare method to compare elements.
func NewSlice ¶
NewSlice creates a new sorted slice.
Parameters:
- elems: The elements to add to the sorted slice.
Returns:
- *Slice[T]: The new sorted slice.
Behaviors:
- Returns nil if the sort function is nil.
func (*Slice[T]) Difference ¶
Difference returns the elements that are in s but not in other.
Parameters:
- other: The slice to compare with.
Returns:
- *Slice[T]: The slice of elements that are in s but not in other.
func (*Slice[T]) Find ¶
Find is the same as Find but uses the Compare method of the elements.
Parameters:
- elem: element to find.
Returns:
- int: index of the first occurrence of the element or -1 if not found.
Behaviors:
- The values must be sorted in ascending order for the Compare method to work.
func (*Slice[T]) FindSubsliceFrom ¶
FindSubBytesFrom finds the first occurrence of a subslice in a byte slice starting from a given index.
Parameters:
- S: The byte slice to search in.
- subS: The byte slice to search for.
- at: The index to start searching from.
Returns:
- int: The index of the first occurrence of the subslice.
Behavior:
- The function uses the Knuth-Morris-Pratt algorithm to find the subslice.
- If S or subS is empty, the function returns -1.
- If the subslice is not found, the function returns -1.
- If at is negative, it is set to 0.
func (*Slice[T]) IndexOfDuplicate ¶
IndexOfDuplicate returns the index of the first duplicate element in the slice.
Returns:
- int: index of the first duplicate element.
Behaviors:
- The function returns -1 if no duplicates are found.
func (*Slice[T]) Insert ¶
Insert inserts an element into the sorted slice.
Parameters:
- elem: The element to insert.
- force: If true, the element is inserted even if it is already in the slice.
Returns:
- int: The index where the element was inserted.
Behaviors:
- The function inserts the element in the correct position to maintain the order.
func (*Slice[T]) MergeUnique ¶
MergeUnique merges two slices and removes duplicate elements.
Parameters:
- S1: first slice of elements.
- S2: second slice of elements.
Returns:
- []T: slice of elements with duplicates removed.
Behaviors:
- The function does preserve the order of the elements in the slice.
func (*Slice[T]) TryInsert ¶
TryInsert tries to insert an element into the sorted slice.
Parameters:
- elem: The element to insert.
Returns:
- int: The index where the element would be inserted.
- bool: True if the element is already in the slice, false otherwise.
func (*Slice[T]) Uniquefy ¶
func (s *Slice[T]) Uniquefy()
Uniquefy is the same as Uniquefy but uses the Compare method of the elements.
Parameters:
- S: slice of elements.
Returns:
- []T: slice of elements with duplicates removed.
Behavior:
- The function preserves the order of the elements in the slice.
- The values must be sorted in ascending order for the Compare method to work.
type SortFunc ¶ added in v0.3.20
SortFunc is a function type that defines a comparison function for elements.
Parameters:
- e1: The first element to compare.
- e2: The second element to compare.
Returns:
- int: A negative value if the first element is less than the second element, 0 if they are equal, and a positive value if the first element is greater than the second element.