Click or drag to resize

IStructures Methods

The IStructures type exposes the following members.

Methods
  NameDescription
Public methodAdd
Public methodClear (Inherited from ICollection<IStructure>.)
Public methodContains (Inherited from ICollection<IStructure>.)
Public methodCopyTo (Inherited from ICollection<IStructure>.)
Public methodGetEnumerator
Returns an enumerator that iterates through the collection.
(Inherited from IEnumerable<IStructure>.)
Public methodIndexOf (Inherited from IList<IStructure>.)
Public methodInsert (Inherited from IList<IStructure>.)
Public methodRemove (Inherited from ICollection<IStructure>.)
Public methodRemoveAt (Inherited from IList<IStructure>.)
Top
Extension Methods
  NameDescription
Public Extension MethodBinarySearch<IStructure>(IStructure)Overloaded.
Searches the entire sorted IList<T> for an element and returns the zero-based index of the element.

If the key is not found, a negative number is returned, which can be intepreted as the bitwise complement of the interval of indices that the key is in between, i.e.

list[interval-1] < key < list[interval]

(Defined by GenericExtensions.)
Public Extension MethodCode exampleBinarySearch<IStructure>(Func<IStructure, Int32>)Overloaded.
Searches the entire sorted IList<T> for an element using the provided comparer and returns the zero-based index of the element.

This differs from the "ordinary" binary search in allowing a comparer delegate that defines whether an item is found (returning 0), whether the item in the list is before (<0) or after (>0) that knows how to compare a class with its key. Example, if the list contains classes of type T having an id number and the class is sorted on that id, then the keySelector returns the id number for that class.

Examples
If having a list of doubles, to find 4.5 in the list, use:
int index = list.BinarySearch(d => d.CompareTo(4.5))
(Defined by GenericExtensions.)
Public Extension MethodBinarySearch<IStructure>(IStructure, IComparer<IStructure>)Overloaded.
Searches the entire sorted IList<T> for an element using the provided comparer and returns the zero-based index of the element.

If the key is not found, a negative number is returned, which can be intepreted as the bitwise complement of the interval of indices that the key is in between, i.e.

list[interval-1] < key < list[interval]

(Defined by GenericExtensions.)
Public Extension MethodBinarySearch<IStructure, TKey>(Func<IStructure, TKey>, TKey)Overloaded.
Searches the entire sorted IList<T> for an element and returns the zero-based index of the element.

If the key is not found, a negative number is returned, which can be intepreted as the bitwise complement of the interval of indices that the key is in between, i.e.

list[interval-1] < key < list[interval]

This differs from the "ordinary" binary search in allowing a keySelectorcomparer that knows how to compare a class with its key. Example, if the list contains classes of type T having an id number and the class is sorted on that id, then the keySelector returns the id number for that class.

(Defined by GenericExtensions.)
Public Extension MethodBinarySearch<IStructure, TKey>(Func<IStructure, TKey>, TKey, IComparer<TKey>)Overloaded.
Searches the entire sorted IList<T> for an element using the provided comparer and returns the zero-based index of the element.

If the key is not found, a negative number is returned, which can be intepreted as the bitwise complement of the interval of indices that the key is in between, i.e.

list[interval-1] < key < list[interval]

This differs from the "ordinary" binary search in allowing a keySelectorcomparer that knows how to compare a class with its key. Example, if the list contains classes of type T having an id number and the class is sorted on that id, then the keySelector returns the id number for that class.

(Defined by GenericExtensions.)
Public Extension MethodFindIndex<IStructure>(Predicate<IStructure>)Overloaded.
Searches for an element that matches the conditions defined by the specified predicate, and returns the zero-based index of the first occurrence within the range of elements in the list.
(Defined by GenericExtensions.)
Public Extension MethodFindIndex<IStructure>(Int32, Predicate<IStructure>)Overloaded.
Searches for an element that matches the conditions defined by the specified predicate, and returns the zero-based index of the first occurrence within the range of elements in the List<T> that extends from the specified index to the last element.
(Defined by GenericExtensions.)
Public Extension MethodSort<IStructure>()Overloaded.
Sorts the elements in the entire List{T} using the default comparer.

A quick sort algorithm is used. Quick sort is a un-stable sort algorithm i.e. if two elements are equal their order may not be preserved.

If the provided IList is either an array or a list, the build in sorting method is used (also quick sort).

(Defined by GenericExtensions.)
Public Extension MethodSort<IStructure>(IComparer<IStructure>)Overloaded.
Sorts the elements in the entire List{T} using the provided comparer.

A quick sort algorithm is used. Quick sort is a un-stable sort algorithm i.e. if two elements are equal their order may not be preserved.

If the provided IList is either an array or a list, the build in sorting method is used (also quick sort).

(Defined by GenericExtensions.)
Public Extension MethodSortStable<IStructure>()Overloaded. (Defined by GenericExtensions.)
Public Extension MethodSortStable<IStructure>(IComparer<IStructure>)Overloaded.
Sorts the elements in the entire List{T} using the provided comparer.

A merge sort algorithm is used. merge sort is a stable sort algorithm i.e. if two elements are equal their order are preserved.

(Defined by GenericExtensions.)
Public Extension MethodSortStable<IStructure>(Comparison<IStructure>)Overloaded.
Sorts the elements in the entire List{T} using the provided comparer.

A merge sort algorithm is used. merge sort is a stable sort algorithm i.e. if two elements are equal their order are preserved.

(Defined by GenericExtensions.)
Top
See Also