|
int | level |
| Maximum level of the skiplist.
|
|
std::shared_ptr< Node > | header |
| Pointer to the header node.
|
|
SkipList class implementation with basic methods
◆ SkipList()
data_structures::SkipList::SkipList |
( |
| ) |
|
|
inline |
Skip List constructor. Initializes header, start Node for searching in the list
64 {
66
68 }
int level
Maximum level of the skiplist.
Definition skip_list.cpp:56
std::shared_ptr< Node > header
Pointer to the header node.
Definition skip_list.cpp:57
constexpr int MAX_LEVEL
Maximum level of skip list.
Definition skip_list.cpp:27
◆ deleteElement()
void data_structures::SkipList::deleteElement |
( |
int | key | ) |
|
|
inline |
Deletes an element by key and prints if has been removed successfully
- Parameters
-
key | is number that is used for comparision. |
133 {
135
138
139 for (
int i =
level; i >= 0; i--) {
140 while (x->forward[i] != nullptr && x->forward[i]->key < key) {
141 x = x->forward[i];
142 }
144 }
145
146 x = x->forward[0];
147
148 bool doesnt_exist = (x == nullptr || x->key != key);
149
150 if (!doesnt_exist) {
151 for (
int i = 0; i <=
level; i++) {
152 if (
update[i]->forward[i] != x) {
153 break;
154 }
155 update[i]->forward[i] = x->forward[i];
156 }
157
160 } else {
162 }
163 }
void update(std::vector< int64_t > *segtree, std::vector< int64_t > *lazy, int64_t start, int64_t end, int64_t delta, uint64_t low, uint64_t high, uint64_t pos)
Updates a range of the segment tree.
Definition segtree.cpp:102
◆ displayList()
void data_structures::SkipList::displayList |
( |
| ) |
|
|
inline |
Display skip list level
191 {
193 for (
int i = 0; i <=
level; i++) {
196 while (
node !=
nullptr) {
199 }
201 }
202 }
Definition binary_search_tree.cpp:11
◆ insertElement()
void data_structures::SkipList::insertElement |
( |
int | key, |
|
|
void * | value ) |
|
inline |
Inserts elements with given key and value; It's level is computed by randomLevel() function.
- Parameters
-
key | is number that is used for comparision |
value | pointer to a value, that can be any type |
90 {
95
96 for (
int i =
level; i >= 0; i--) {
97 while (x->forward[i] != nullptr && x->forward[i]->key < key) {
98 x = x->forward[i];
99 }
101 }
102
103 x = x->forward[0];
104
105 bool doesnt_exist = (x == nullptr || x->key != key);
106 if (doesnt_exist) {
108
109 if (rlevel >
level) {
111
112
114 }
115
118 for (int i = 0; i <= rlevel; i++) {
119 n->forward[i] =
update[i]->forward[i];
120 update[i]->forward[i] = n;
121 }
123
124 } else {
126 }
127 }
int randomLevel()
Definition skip_list.cpp:75
◆ randomLevel()
int data_structures::SkipList::randomLevel |
( |
| ) |
|
|
inline |
Returns random level of the skip list. Every higher level is 2 times less likely.
- Returns
- random level for skip list
75 {
76 int lvl = 0;
79 lvl++;
80 }
81 return lvl;
82 }
constexpr float PROBABILITY
Current probability for "coin toss".
Definition skip_list.cpp:28
◆ searchElement()
void * data_structures::SkipList::searchElement |
( |
int | key | ) |
|
|
inline |
Searching element in skip list structure
- Parameters
-
key | is number that is used for comparision |
- Returns
- pointer to the value of the node
170 {
173
174 for (
int i =
level; i >= 0; i--) {
175 while (x->forward[i] && x->forward[i]->key < key) x = x->forward[i];
176 }
177
178 x = x->forward[0];
179 if (x && x->key == key) {
181 return x->value;
182 } else {
184 return nullptr;
185 }
186 }
The documentation for this class was generated from the following file: