forked from hunterzhao/EasySTL
-
Notifications
You must be signed in to change notification settings - Fork 0
/
RBtreeIterator.h
113 lines (98 loc) · 2.88 KB
/
RBtreeIterator.h
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
#ifndef _RBTREE_H_
#define _RBTREE_H_
#include "iterator.h"
namespace EasySTL {
typedef bool __rb_tree_color_type;
const __rb_tree_color_type __rb_tree_red = false;
const __rb_tree_color_type __rb_tree_black = true;
struct __rb_tree_node_base {
typedef __rb_tree_color_type color_type;
typedef __rb_tree_node_base* base_ptr;
color_type color;
base_ptr parent;
base_ptr left;
base_ptr right;
static base_ptr minimum(base_ptr x) {
while (x->left != 0) x=x->left;
return x;
}
static base_ptr maximum(base_ptr x) {
while (x->right != 0) x=x->right;
return x;
}
};
template <class Value>
struct __rb_tree_node : public __rb_tree_node_base {
typedef __rb_tree_node<Value>* link_type;
Value value_field;
};
struct __rb_tree_base_iterator {
typedef __rb_tree_node_base::base_ptr base_ptr;
typedef bidirectional_iterator_tag iterator_category;
typedef ptrdiff_t difference_type;
base_ptr node;//make a reference
void increment() {
if (node->right != 0) {
node = node->right;
while(node->left != 0) node = node->left;
} else {
base_ptr y = node->parent;//父节点不一定大于自己
while(node == y->right) {
node = y;
y = y->parent;
}
if (node->right != y)
node = y;
}
}
void decrement() {
if (node->color == __rb_tree_red &&
node->parent->parent == node)
node = node->right;
else if (node->left != 0) {
base_ptr y = node->left;
while(y->right != 0) y = y->right;
node = y;
} else {
base_ptr y = node->parent;
while (node == y->left) {
node = y;
y = y->parent;
}
node = y;
}
}
};
template <class Value, class Ref, class Ptr>
struct __rb_tree_iterator : public __rb_tree_base_iterator {
typedef Value value_type;
typedef Ref reference;
typedef Ptr pointer;
typedef __rb_tree_iterator<Value, Value&, Value*> iterator;
typedef __rb_tree_iterator<Value, const Value&, const Value*> const_iterator;
typedef __rb_tree_iterator<Value, Ref, Ptr> self;
typedef __rb_tree_node<Value>* link_type;
__rb_tree_iterator() {}
__rb_tree_iterator(link_type x) {node = x;}
__rb_tree_iterator(const iterator& it) { node = it.node;}
reference operator*() const { return link_type(node)->value_field;}
pointer operator->() const { return &(operator*());}
self& operator++() {increment(); return *this;}
self operator++(int) {
self tmp = *this;
increment();
return tmp;
}
self& operator--() { decrement(); return *this;}
self operator--(int) {
self tmp = *this;
decrement();
return tmp;
}
bool operator==(const self& iter) const { return node == iter.node;}
bool operator!=(const self& iter) const { return node != iter.node;}
// bool operator==(const self& x) const {return node == x.node;}
// bool operator!=(const self& x) const {return node != x.node;}
};
}
#endif