Class LinkedListWithClassNode<T>
- Namespace
- AlgorithmsSW.List
- Assembly
- AlgorithmsSW.dll
Represents a singly linked list.
public sealed class LinkedListWithClassNode<T> : IEnumerable<T>, IEnumerable
Type Parameters
T
The type of elements in the LinkedListWithClassNode<T>.
- Inheritance
-
LinkedListWithClassNode<T>
- Implements
-
IEnumerable<T>
- Inherited Members
- Extension Methods
Properties
Count
Gets the number of elements contained in the LinkedListWithClassNode<T>.
public int Count { get; }
Property Value
First
Gets the first node of the LinkedListWithClassNode<T>.
public LinkedListWithClassNode<T>.Node First { get; }
Property Value
Exceptions
- InvalidOperationException
Thrown when the LinkedListWithClassNode<T> is empty.
IsEmpty
Gets a value indicating whether the linked list is empty.
public bool IsEmpty { get; }
Property Value
IsSingleton
Gets a value indicating whether the linked list has only one item.
public bool IsSingleton { get; }
Property Value
Last
Gets the last node of the linked list.
public LinkedListWithClassNode<T>.Node Last { get; }
Property Value
Exceptions
- InvalidOperationException
Thrown when the linked list is empty.
Nodes
Gets an enumerable collection of nodes in the linked list.
public IEnumerable<LinkedListWithClassNode<T>.Node> Nodes { get; }
Property Value
Methods
Clear()
Removes all nodes from this LinkedListWithClassNode<T>.
public void Clear()
Concat(LinkedListWithClassNode<T>)
Concatenates the current LinkedListWithClassNode<T> with another LinkedListWithClassNode<T>.
public void Concat(LinkedListWithClassNode<T> other)
Parameters
other
LinkedListWithClassNode<T>The LinkedListWithClassNode<T> to concatenate with.
GetEnumerator()
Returns an enumerator that iterates through the collection.
public IEnumerator<T> GetEnumerator()
Returns
- IEnumerator<T>
An enumerator that can be used to iterate through the collection.
InsertAfter(Node, T)
Inserts a new item after the specified node in the linked list.
public LinkedListWithClassNode<T>.Node InsertAfter(LinkedListWithClassNode<T>.Node node, T item)
Parameters
node
LinkedListWithClassNode<T>.NodeThe node after which to insert the new item.
item
TThe item to insert.
Returns
- LinkedListWithClassNode<T>.Node
The newly created node containing the inserted item.
InsertAtBack(T)
Inserts a new item at the end of the linked list.
public LinkedListWithClassNode<T>.Node InsertAtBack(T item)
Parameters
item
TThe item to insert.
Returns
- LinkedListWithClassNode<T>.Node
The newly created node containing the inserted item.
InsertAtFront(T)
Inserts a new item at the beginning of the linked list.
public LinkedListWithClassNode<T>.Node InsertAtFront(T item)
Parameters
item
TThe item to insert.
Returns
- LinkedListWithClassNode<T>.Node
The newly created node containing the inserted item.
RemoveAfter(Node)
Removes the node after the specified node.
public LinkedListWithClassNode<T>.Node RemoveAfter(LinkedListWithClassNode<T>.Node node)
Parameters
node
LinkedListWithClassNode<T>.NodeThe node whose successor is to be removed.
Returns
- LinkedListWithClassNode<T>.Node
The removed node.
Exceptions
- ArgumentNullException
Thrown when the input node is null.
- InvalidOperationException
Thrown when the input node does not have a successor to remove.
RemoveFromFront()
Removes the first item from the linked list.
public LinkedListWithClassNode<T>.Node RemoveFromFront()
Returns
- LinkedListWithClassNode<T>.Node
The removed node.
Reverse()
Reverses the order of the nodes in the linked list.
public void Reverse()
ToString()
Returns a string that represents the current object.
public override string ToString()
Returns
- string
A string that represents the current object.