It has been 420 days since the last update, the content of the article may be outdated.
定义
是一种可以代替平衡树的数据结构,可以看做是并联的有序链表。跳跃表通过概率保证平衡,而平衡树采用严格的旋转来保证平衡,因此跳跃表比较容易实现,而且相比平衡树有着较高的运行效率。下面实现的最大level为16.
操作
这里是一个单向链表,其实也可以维护一个双向的链表
实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135
| #include <iostream> #include <vector> #include <random> #include <climits>
const int MAX_LEVEL = 16;
struct SkipListNode { int value; std::vector<SkipListNode*> next;
SkipListNode(int val, int level) : value(val), next(level, nullptr) {} };
class SkipList { public: SkipList() { head = new SkipListNode(INT_MIN, MAX_LEVEL); tail = new SkipListNode(INT_MAX, MAX_LEVEL); for (int i = 0; i < MAX_LEVEL; ++i) { head->next[i] = tail; } }
~SkipList() { SkipListNode* curr = head; while (curr != nullptr) { SkipListNode* temp = curr; curr = curr->next[0]; delete temp; } }
void insert(int value) { std::vector<SkipListNode*> update(MAX_LEVEL, nullptr); SkipListNode* curr = head; for (int i = MAX_LEVEL - 1; i >= 0; --i) { while (curr->next[i]->value < value) { curr = curr->next[i]; } update[i] = curr; } curr = curr->next[0]; if (curr->value == value) { return; } int level = randomLevel(); SkipListNode* newNode = new SkipListNode(value, level); for (int i = 0; i < level; ++i) { newNode->next[i] = update[i]->next[i]; update[i]->next[i] = newNode; } }
void remove(int value) { std::vector<SkipListNode*> update(MAX_LEVEL, nullptr); SkipListNode* curr = head; for (int i = MAX_LEVEL - 1; i >= 0; --i) { while (curr->next[i]->value < value) { curr = curr->next[i]; } update[i] = curr; } curr = curr->next[0]; if (curr->value != value) { return; } for (int i = 0; i < curr->next.size()&& i < update.size(); ++i) { if (update[i]->next[i] != curr) { break; } update[i]->next[i] = curr->next[i]; } delete curr; }
bool search(int value) { SkipListNode* curr = head; for (int i = MAX_LEVEL - 1; i >= 0; --i) { while (curr->next[i]->value < value) { curr = curr->next[i]; } } curr = curr->next[0]; return curr->value == value; }
void print() { for (int i = MAX_LEVEL - 1; i >= 0; --i) { SkipListNode* curr = head->next[i]; std::cout << "Level " << i << ": "; while (curr != tail) { std::cout << curr->value << " "; curr = curr->next[i]; } std::cout << std::endl; } }
private: SkipListNode* head; SkipListNode* tail;
int randomLevel() { std::random_device rd; std::mt19937 gen(rd()); std::uniform_int_distribution<> dis(1, MAX_LEVEL); return dis(gen); } };
int main() { SkipList skipList; skipList.insert(3); skipList.insert(1); skipList.insert(5); skipList.insert(2); skipList.insert(4); skipList.print();
std::cout << "Search 3: " << (skipList.search(3) ? "Found" : "Not Found") << std::endl; std::cout << "Search 6: " << (skipList.search(6) ? "Found" : "Not Found") << std::endl;
skipList.remove(2); skipList.remove(4); skipList.print();
return 0; }
|