Skip to content

Commit

Permalink
Addes Create
Browse files Browse the repository at this point in the history
  • Loading branch information
lrleon committed Apr 13, 2021
1 parent 1eff977 commit b27efb9
Showing 1 changed file with 24 additions and 20 deletions.
44 changes: 24 additions & 20 deletions slist.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ func (seq *Slist) Swap(rhs interface{}) interface{} {
return seq
}

// Create a new sequence with the received items
// New Create a new sequence with the received items
func New(items ...interface{}) *Slist {

seq := new(Slist)
Expand All @@ -34,13 +34,17 @@ func New(items ...interface{}) *Slist {
return seq
}

// Return true if sequence is empty
func (seq *Slist) Create(items ...interface{}) interface{} {
return New(items...)
}

// IsEmpty Return true if sequence is empty
func (seq *Slist) IsEmpty() bool {

return seq.head == nil && seq.tail == nil // double check!
}

// Return a slice with the elements of the list
// ToSlice Return a slice with the elements of the list
func (seq *Slist) ToSlice() []interface{} {

ret := make([]interface{}, 0, 4)
Expand Down Expand Up @@ -101,7 +105,7 @@ func (seq *Slist) Insert(item interface{}, items ...interface{}) *Slist {
return result
}

// Remove the first item of the sequence
// RemoveFirst Remove the first item of the sequence
func (seq *Slist) RemoveFirst() interface{} {

if seq.IsEmpty() {
Expand All @@ -116,7 +120,7 @@ func (seq *Slist) RemoveFirst() interface{} {
return ret
}

// Return the first element of the list
// First Return the first element of the list
func (seq *Slist) First() interface{} {

if seq == nil {
Expand All @@ -125,15 +129,15 @@ func (seq *Slist) First() interface{} {
return seq.head.item
}

// Return the last element of the list
// Last Return the last element of the list
func (seq *Slist) Last() interface{} {
if seq == nil {
return nil
}
return seq.tail.item
}

// Return true if the list is empty
// Empty Return true if the list is empty
func (seq *Slist) Empty() *Slist {
seq.head = nil
seq.tail = nil
Expand All @@ -159,7 +163,7 @@ func (seq *Slist) staticAppendList(l *Slist) *Slist {
return seq
}

// Append to seq the received lists. Complexity O(n) where n is the number of received list
// AppendList Append to seq the received lists. Complexity O(n) where n is the number of received list
func (seq *Slist) AppendList(l *Slist, ln ...*Slist) *Slist {
seq.staticAppendList(l)
for _, ll := range ln {
Expand All @@ -173,46 +177,46 @@ type Iterator struct {
curr *Snode
}

// Return an iterator to the list
// NewIterator Return an iterator to the list
func NewIterator(seq *Slist) *Iterator {
it := new(Iterator)
it.listPtr = seq
it.curr = seq.head
return it
}

// Return an iterator to the list
// CreateIterator Return an iterator to the list
func (seq *Slist) CreateIterator() interface{} {

return NewIterator(seq)
}

// Reset the iterator to the first element of the list
// ResetFirst Reset the iterator to the first element of the list
func (it *Iterator) ResetFirst() interface{} {

it.curr = it.listPtr.head
return it
}

// Return true if the iterator is positioned on a valid element
// HasCurr Return true if the iterator is positioned on a valid element
func (it *Iterator) HasCurr() bool {
return it.curr != nil
}

// Return true if the current element of the list is the last of the list
// IsLast Return true if the current element of the list is the last of the list
func (it *Iterator) IsLast() bool {
return it.curr == it.listPtr.tail
}

// Return the current element of the list
// GetCurr Return the current element of the list
func (it *Iterator) GetCurr() interface{} {
if it.curr == nil {
return nil
}
return it.curr.item
}

// Advance the iterator to the next element of the list
// Next Advance the iterator to the next element of the list
func (it *Iterator) Next() interface{} {
it.curr = it.curr.next
if it.curr == nil {
Expand All @@ -221,7 +225,7 @@ func (it *Iterator) Next() interface{} {
return it
}

// Return the number of elements of the list
// Size Return the number of elements of the list
func (seq *Slist) Size() int {

n := 0
Expand Down Expand Up @@ -252,7 +256,7 @@ func (seq *Slist) clone() *Slist {
return ret
}

// Reverse the list in place
// ReverseInPlace Reverse the list in place
func (seq *Slist) ReverseInPlace() *Slist {

tmp := New()
Expand All @@ -264,12 +268,12 @@ func (seq *Slist) ReverseInPlace() *Slist {
return seq.Swap(tmp).(*Slist)
}

// Return a reversed copy of seq
// Reverse Return a reversed copy of seq
func (seq *Slist) Reverse() *Slist {
return seq.clone().ReverseInPlace()
}

// Rotate in place n positions to left
// RotateLeftInPlace Rotate in place n positions to left
func (seq *Slist) RotateLeftInPlace(n int) *Slist {

if seq.IsEmpty() || n == 0 {
Expand All @@ -283,7 +287,7 @@ func (seq *Slist) RotateLeftInPlace(n int) *Slist {
return seq
}

// Return a copy of seq rotated n positions to left
// RotateLeft Return a copy of seq rotated n positions to left
func (seq *Slist) RotateLeft(n int) *Slist {
return seq.clone().RotateLeftInPlace(n)
}

0 comments on commit b27efb9

Please sign in to comment.