mirror of
https://github.com/duke-git/lancet.git
synced 2026-02-17 03:02:28 +08:00
feat: add func Iterator, ForEach, RetainAll and DeleteAll for List structure (#71)
This commit is contained in:
@@ -5,6 +5,7 @@
|
|||||||
package datastructure
|
package datastructure
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/duke-git/lancet/v2/iterator"
|
||||||
"reflect"
|
"reflect"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -323,3 +324,46 @@ func (l *List[T]) SubList(fromIndex, toIndex int) *List[T] {
|
|||||||
copy(subList, data)
|
copy(subList, data)
|
||||||
return NewList(subList)
|
return NewList(subList)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ForEach performs the given action for each element of the list.
|
||||||
|
func (l *List[T]) ForEach(consumer func(T)) {
|
||||||
|
for _, it := range l.data {
|
||||||
|
consumer(it)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// RetainAll retains only the elements in this list that are contained in the given list.
|
||||||
|
func (l *List[T]) RetainAll(list *List[T]) bool {
|
||||||
|
return l.batchRemove(list, true)
|
||||||
|
}
|
||||||
|
|
||||||
|
// DeleteAll removes from this list all of its elements that are contained in the given list.
|
||||||
|
func (l *List[T]) DeleteAll(list *List[T]) bool {
|
||||||
|
return l.batchRemove(list, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (l *List[T]) batchRemove(list *List[T], complement bool) bool {
|
||||||
|
var (
|
||||||
|
w = 0
|
||||||
|
data = l.data
|
||||||
|
size = len(data)
|
||||||
|
)
|
||||||
|
|
||||||
|
for i := 0; i < size; i++ {
|
||||||
|
if list.Contain(data[i]) == complement {
|
||||||
|
data[w] = data[i]
|
||||||
|
w++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if w != size {
|
||||||
|
l.data = data[:w]
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
// Iterator returns an iterator over the elements in this list in proper sequence.
|
||||||
|
func (l *List[T]) Iterator() iterator.Iterator[T] {
|
||||||
|
return iterator.FromSlice(l.data)
|
||||||
|
}
|
||||||
|
|||||||
@@ -357,3 +357,71 @@ func TestDeleteIf(t *testing.T) {
|
|||||||
assert.Equal([]int{2, 3, 4}, list.Data())
|
assert.Equal([]int{2, 3, 4}, list.Data())
|
||||||
assert.Equal(0, count)
|
assert.Equal(0, count)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestForEach(t *testing.T) {
|
||||||
|
assert := internal.NewAssert(t, "TestForEach")
|
||||||
|
|
||||||
|
list := NewList([]int{1, 2, 3, 4})
|
||||||
|
|
||||||
|
rs := make([]int, 0)
|
||||||
|
list.ForEach(func(i int) {
|
||||||
|
rs = append(rs, i)
|
||||||
|
})
|
||||||
|
|
||||||
|
assert.Equal([]int{1, 2, 3, 4}, rs)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRetainAll(t *testing.T) {
|
||||||
|
assert := internal.NewAssert(t, "TestRetainAll")
|
||||||
|
|
||||||
|
list := NewList([]int{1, 2, 3, 4})
|
||||||
|
list1 := NewList([]int{1, 2, 3, 4})
|
||||||
|
list2 := NewList([]int{1, 2, 3, 4})
|
||||||
|
|
||||||
|
retain := NewList([]int{1, 2})
|
||||||
|
retain1 := NewList([]int{2, 3})
|
||||||
|
retain2 := NewList([]int{1, 2, 5})
|
||||||
|
|
||||||
|
list.RetainAll(retain)
|
||||||
|
list1.RetainAll(retain1)
|
||||||
|
list2.RetainAll(retain2)
|
||||||
|
|
||||||
|
assert.Equal([]int{1, 2}, list.Data())
|
||||||
|
assert.Equal([]int{2, 3}, list1.Data())
|
||||||
|
assert.Equal([]int{1, 2}, list2.Data())
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestDeleteAll(t *testing.T) {
|
||||||
|
assert := internal.NewAssert(t, "TestDeleteAll")
|
||||||
|
|
||||||
|
list := NewList([]int{1, 2, 3, 4})
|
||||||
|
list1 := NewList([]int{1, 2, 3, 4})
|
||||||
|
list2 := NewList([]int{1, 2, 3, 4})
|
||||||
|
|
||||||
|
del := NewList([]int{1})
|
||||||
|
del1 := NewList([]int{2, 3})
|
||||||
|
del2 := NewList([]int{1, 2, 5})
|
||||||
|
|
||||||
|
list.DeleteAll(del)
|
||||||
|
list1.DeleteAll(del1)
|
||||||
|
list2.DeleteAll(del2)
|
||||||
|
assert.Equal([]int{2, 3, 4}, list.Data())
|
||||||
|
assert.Equal([]int{1, 4}, list1.Data())
|
||||||
|
assert.Equal([]int{3, 4}, list2.Data())
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestIterator(t *testing.T) {
|
||||||
|
assert := internal.NewAssert(t, "TestIterator")
|
||||||
|
|
||||||
|
list := NewList([]int{1, 2, 3, 4})
|
||||||
|
|
||||||
|
iterator := list.Iterator()
|
||||||
|
|
||||||
|
rs := make([]int, 0)
|
||||||
|
for iterator.HasNext() {
|
||||||
|
item, _ := iterator.Next()
|
||||||
|
rs = append(rs, item)
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.Equal([]int{1, 2, 3, 4}, rs)
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user