123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- \chapter{TSet}
- Implements container for storing ordered set of unique elements.
- Takes 2 arguments for specialization, first one is type of elements, second one is comparator class.
- Usage example:
- \lstinputlisting[language=Pascal]{setexample.pp}
- Memory complexity:
- Size of stored elements + constant overhead for each stored element (3 pointers + one boolean).
- Members list:
- \begin{longtable}{|m{10cm}|m{5cm}|}
- \hline
- Method & Complexity guarantees \\ \hline
- \multicolumn{2}{|m{15cm}|}{Description} \\ \hline\hline
- \verb!Create! & O(1) \\ \hline
- \multicolumn{2}{|m{15cm}|}{Constructor. Creates empty set.} \\ \hline\hline
- \verb!function Size(): SizeUInt! & O(1) \\ \hline
- \multicolumn{2}{|m{15cm}|}{Returns number of elements in set.} \\\hline\hline
- \verb!procedure Insert(value: T)! &
- O(lg N), N is number of elements in set \\ \hline
- \multicolumn{2}{|m{15cm}|}{Inserts element into set, if given element is already there nothing
- happens.} \\\hline\hline
- \verb!function InsertAndGetIterator! & $O(\lg N)$\\
- \verb!(value: T):TIterator! & \\ \hline
- \multicolumn{2}{|m{15cm}|}{Inserts element into set, if given element is already there nothing
- happens. Also returns iterator pointing on given element.} \\\hline\hline
- \verb!procedure Delete(value: T)! &
- O(lg N), N is number of elements in set \\ \hline
- \multicolumn{2}{|m{15cm}|}{Deletes value from set. If element is not in set, nothing happens.} \\\hline\hline
- \verb!function Find(value: T):TIterator! & O(lg N) \\\hline
- \multicolumn{2}{|m{15cm}|}{Searches for value in set. If value is not there returns nil. Otherwise
- returns iterator, which can be used for retrieving data from set.} \\\hline\hline
- \verb!function FindLess(value: T):TIterator! & O(lg N) \\\hline
- \multicolumn{2}{|m{15cm}|}{Searches for greatest element less than value in set. If such element is not there returns nil. Otherwise
- returns iterator, which can be used for retrieving data from set.} \\\hline\hline
- \verb!function FindLessEqual(value: T):TIterator! & O(lg N) \\\hline
- \multicolumn{2}{|m{15cm}|}{Searches for greatest element less or equal than value in set. If such element is not there returns nil. Otherwise
- returns iterator, which can be used for retrieving data from set.} \\\hline\hline
- \verb!function FindGreater(value: T):TIterator! & O(lg N) \\\hline
- \multicolumn{2}{|m{15cm}|}{Searches for smallest element greater than value in set. If such element is not there returns nil. Otherwise
- returns iterator, which can be used for retrieving data from set.} \\\hline\hline
- \verb!function FindGreaterEqual(value: T):TIterator! & O(lg N) \\\hline
- \multicolumn{2}{|m{15cm}|}{Searches for smallest element greater or equal than value in set. If such element is not there returns nil. Otherwise
- returns iterator, which can be used for retrieving data from set.} \\\hline\hline
- \verb!function Min:TIterator! & O(lg N) \\\hline
- \multicolumn{2}{|m{15cm}|}{Returns iterator pointing to the smallest element of set. If set is empty returns
- nil.} \\\hline\hline
- \verb!function Max:TIterator! & O(lg N) \\\hline
- \multicolumn{2}{|m{15cm}|}{Returns iterator pointing to the largest element of set. If set is empty returns
- nil.} \\\hline\hline
- \verb!function IsEmpty(): boolean! & O(1) \\ \hline
- \multicolumn{2}{|m{15cm}|}{Returns true when set is empty.} \\\hline
- \end{longtable}
- Some methods return type TIterator, which has following methods:
- \begin{longtable}{|m{10cm}|m{5cm}|}
- \hline
- Method & Complexity guarantees \\ \hline
- \multicolumn{2}{|m{15cm}|}{Description} \\ \hline\hline
- \verb!function Next:boolean! & O(lg N) worst case, but traversal from smallest element to
- largest takes O(N) time \\\hline
- \multicolumn{2}{|m{15cm}|}{Moves iterator to smallest larger element in set. Returns true on
- success. If the iterator is already pointing on largest element returns false.} \\\hline\hline
- \verb!function Prev:boolean! & O(lg N) worst case, but traversal from largest element to
- smallest takes O(N) time \\\hline
- \multicolumn{2}{|m{15cm}|}{Moves iterator to largest smaller element in set. Returns true on
- success. If the iterator is already pointing on smallest element returns false.} \\\hline\hline
- \verb!property Data:T! & $O(1)$ \\\hline
- \multicolumn{2}{|m{15cm}|}{Property, which allows reading of the element.} \\\hline
- \end{longtable}
|