Table of Contents

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
Inherited Members
Extension Methods

Properties

Count

Gets the number of elements contained in the LinkedListWithClassNode<T>.

public int Count { get; }

Property Value

int

First

Gets the first node of the LinkedListWithClassNode<T>.

public LinkedListWithClassNode<T>.Node First { get; }

Property Value

LinkedListWithClassNode<T>.Node

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

bool

IsSingleton

Gets a value indicating whether the linked list has only one item.

public bool IsSingleton { get; }

Property Value

bool

Last

Gets the last node of the linked list.

public LinkedListWithClassNode<T>.Node Last { get; }

Property Value

LinkedListWithClassNode<T>.Node

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

IEnumerable<LinkedListWithClassNode<T>.Node>

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>.Node

The node after which to insert the new item.

item T

The 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 T

The 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 T

The 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>.Node

The 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.