annotate src/main/csharp/jp.ac.u-ryukyu.ie.cr/jungle/data/treemap/TreeMapNode.cs @ 0:dec15de2c6ff

first commit
author Kazuma
date Tue, 21 Jun 2016 17:11:12 +0900
parents
children 5c58219da97e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
1 using System.Collections;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
2 using System;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
3 using UnityEngine;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
4
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
5
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
6 public abstract class TreeMapNode<K,V>
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
7 {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
8 // K,Vがnullableではないので受け付けない
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
9 // ジェネリックの扱いがJavaとちがうー>特にnullの扱いが面倒。
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
10 protected K key;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
11 protected V value;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
12 protected TreeMapNode<K,V> right;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
13 protected TreeMapNode<K,V> left;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
14
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
15 void Start(){
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
16 key = default(K);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
17 value = default(V);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
18 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
19
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
20 // Use this for initialization
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
21 public TreeMapNode (K key, V value)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
22 {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
23 this.key = key;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
24 this.value = value;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
25 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
26
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
27 public TreeMapNode (K key, V value, TreeMapNode<K,V> left, TreeMapNode<K,V> right)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
28 {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
29 this.key = key;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
30 this.value = value;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
31 this.right = right;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
32 this.left = left;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
33 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
34
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
35 public TreeMapNode<K,V> lefts ()
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
36 {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
37 return left;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
38 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
39
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
40
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
41 public int compare(K compareKey, Comparer ctr) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
42 return ctr.Compare(compareKey, this.getKey());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
43 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
44
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
45 public V get (K key, Comparer ctr)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
46 {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
47 TreeMapNode<K,V> cur = this;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
48 int result = cur.compare (key, ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
49 while (cur.isNotEmpty ()) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
50 if (result > 0) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
51 cur = cur.rights ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
52 Debug.Log (cur);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
53 } else if (result < 0) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
54 cur = cur.lefts ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
55 } else if (result == 0) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
56 if (cur != null) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
57 return cur.getValue ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
58 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
59 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
60 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
61 return default(V); // Optional<V>.ofNullable (null);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
62 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
63
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
64
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
65
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
66 public TreeMapNode<K,V> rights () {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
67 return right;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
68 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
69
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
70 public K getKey () {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
71 return key;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
72 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
73
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
74 public V getValue () {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
75 return value;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
76 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
77
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
78 // may be to use Comparer??
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
79 public TreeMapNode<K,V> put (K k, V v,Comparer ctr) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
80
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
81 if (!isNotEmpty ()) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
82 return createNode (k, value, left, right);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
83 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
84
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
85 int result = compare (k,ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
86 if (result > 0) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
87 TreeMapNode<K,V> node = right.put (k, value,ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
88 node = createNode (key, this.value, left, node);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
89 return node.insBalance ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
90 } else if (result < 0) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
91 TreeMapNode<K,V> node = left.put (k, value,ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
92 return createNode (key, this.value, node, right).insBalance ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
93 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
94 return createNode (key, value, left, right);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
95 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
96
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
97 public rebuildNode<K,V> delete (K key, TreeMapNode<K,V> parent, Comparer ctr, Rotate side)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
98 {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
99 if (this.isNotEmpty ()) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
100 rebuildNode<K,V> rebuildNode;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
101 int result = compare(key, ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
102 if (result > 0) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
103 rebuildNode = right.delete (key, this, ctr, Rotate.R);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
104 } else if (result < 0) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
105 rebuildNode = left.delete (key, this, ctr, Rotate.L);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
106 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
107 rebuildNode = replaceNode (parent, ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
108 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
109 if (parent == null) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
110 return rebuildNode;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
111 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
112 TreeMapNode<K,V> node = rebuildNode.getNode ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
113 if (rebuildNode.rebuilds ()) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
114 // ここのエラーは後で
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
115 return node.deleteBalance (parent, ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
116 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
117 TreeMapNode<K,V> newParent;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
118 if (side == Rotate.L) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
119 newParent = parent.createNode (parent.getKey (), parent.getValue (), node, parent.rights ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
120 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
121 newParent = parent.createNode (parent.getKey (), parent.getValue (), parent.lefts (), node);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
122 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
123 return new rebuildNode<K,V> (false, newParent);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
124 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
125 return null;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
126 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
127
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
128 public rebuildNode<K,V> deleteSubTreeMaxNode (TreeMapNode<K, V> parent, Comparer ctr, Rotate side)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
129 {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
130 rebuildNode<K,V> rebuildNode;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
131 TreeMapNode<K, V> node;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
132 if (rights ().isNotEmpty ()) {// 最大値のノードが取得できるまで潜る
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
133 rebuildNode = rights ().deleteSubTreeMaxNode (this, ctr, Rotate.R);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
134 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
135 rebuildNode = this.replaceNode (parent, ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
136 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
137 if (parent == null)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
138 return rebuildNode;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
139
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
140 if (rebuildNode.rebuilds ()) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
141 node = rebuildNode.getNode ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
142 return node.deleteBalance (parent, ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
143 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
144 if (side == Rotate.R)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
145 node = parent.createNode (parent.getKey (), parent.getValue (), parent.lefts (), rebuildNode.getNode ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
146 else
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
147 node = parent.createNode (parent.getKey (), parent.getValue (), rebuildNode.getNode (), parent.rights ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
148 return new rebuildNode<K,V> (false, node);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
149 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
150
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
151
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
152 public rebuildNode<K, V> deleteBalance (TreeMapNode<K, V> parent, Comparer ctr)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
153 {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
154 TreeMapNode<K, V> newNode = null;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
155 if (!isRed ()) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
156 if (0 > compare (parent.getKey (), ctr)) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
157 bool rightChild = parent.lefts ().rights ().isRed ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
158 bool leftChild = parent.lefts ().lefts ().isRed ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
159
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
160 if (!parent.isRed ()) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
161 if (!parent.lefts ().isRed ()) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
162 if (!rightChild && !leftChild) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
163 newNode = rebuildThree (parent, Rotate.R);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
164 return new rebuildNode<K,V> (true, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
165 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
166 if (rightChild) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
167 newNode = rebuildfive (parent, Rotate.R);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
168 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
169 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
170 newNode = rebuildsix (parent, Rotate.R);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
171 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
172 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
173 } else { // 左の子が赤
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
174 newNode = rebuildTwo (parent, ctr, Rotate.R);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
175 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
176 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
177 } else { // 親が赤
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
178 if (!rightChild && !leftChild) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
179 newNode = rebuildFour (parent, Rotate.R);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
180 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
181 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
182 if (rightChild) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
183 newNode = rebuildfive (parent, Rotate.R);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
184 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
185 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
186 newNode = rebuildsix (parent, Rotate.R);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
187 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
188 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
189 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
190 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
191 bool rightChild = parent.rights ().rights ().isRed ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
192 bool leftChild = parent.rights ().lefts ().isRed ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
193
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
194 if (!parent.isRed ()) { // 親が黒
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
195 if (!parent.rights ().isRed ()) { // 左の子が黒
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
196 if (!rightChild && !leftChild) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
197 newNode = rebuildThree (parent, Rotate.L);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
198 return new rebuildNode<K,V> (true, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
199 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
200 if (rightChild) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
201 newNode = rebuildsix (parent, Rotate.L);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
202 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
203 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
204 newNode = rebuildfive (parent, Rotate.L);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
205 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
206 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
207 } else { // 左の子が赤
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
208 newNode = rebuildTwo (parent, ctr, Rotate.L);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
209 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
210 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
211 } else { // 親が赤
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
212 if (!rightChild && !leftChild) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
213 newNode = rebuildFour (parent, Rotate.L);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
214 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
215 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
216 if (rightChild) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
217 newNode = rebuildsix (parent, Rotate.L);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
218 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
219 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
220 newNode = rebuildfive (parent, Rotate.L);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
221 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
222 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
223 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
224 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
225 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
226 if (0 > (compare (parent.getKey (), ctr))) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
227 newNode = parent.createNode (parent.getKey (), parent.getValue (), parent.lefts (), this);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
228 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
229 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
230 newNode = parent.createNode (parent.getKey (), parent.getValue (), this, parent.rights ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
231 return new rebuildNode<K,V> (false, newNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
232 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
233 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
234
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
235 protected TreeMapNode<K, V> rebuildTwo (TreeMapNode<K, V> parent, Comparer ctr, Rotate side)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
236 { // case2
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
237 if (side == Rotate.L) { // rotate Left
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
238 TreeMapNode<K, V> node = parent.rights ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
239 TreeMapNode<K, V> leftSubTreeRoot = node.createNode (parent.getKey (), parent.getValue (), this, node.lefts ()); // check
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
240 rebuildNode<K, V> rebuildNode = new rebuildNode<K,V> (false, leftSubTreeRoot);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
241 rebuildNode<K, V> leftNodeRebuildNode = this.deleteBalance (rebuildNode.getNode (), ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
242 TreeMapNode<K, V> rightNode = node.rights ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
243 return parent.createNode (node.getKey (), node.getValue (), leftNodeRebuildNode.getNode (), rightNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
244 } else { // rotate Right
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
245 TreeMapNode<K, V> node = parent.lefts ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
246 TreeMapNode<K, V> rightSubTreeRoot = node.createNode (parent.getKey (), parent.getValue (), node.rights (), this);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
247 rebuildNode<K, V> rightSubTreeRebuildNode = new rebuildNode<K,V> (false, rightSubTreeRoot);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
248 rebuildNode<K, V> rightNodeRebuildNode = this.deleteBalance (rightSubTreeRebuildNode.getNode (), ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
249 TreeMapNode<K, V> leftNode = node.lefts ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
250 return parent.createNode (node.getKey (), node.getValue (), leftNode, rightNodeRebuildNode.getNode ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
251 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
252 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
253
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
254 protected TreeMapNode<K, V> rebuildThree (TreeMapNode<K, V> parent, Rotate side)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
255 { // case3 再帰
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
256 if (side == Rotate.L) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
257 TreeMapNode<K, V> rightNode;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
258 if (parent.rights ().isNotEmpty ())
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
259 rightNode = new RedNode<K,V> (parent.rights ().getKey (), parent.rights ().getValue (), parent.rights ().lefts (), parent.rights ().rights ()); // check
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
260 else
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
261 rightNode = new EmptyNode<K,V> ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
262 return parent.createNode (parent.getKey (), parent.getValue (), this, rightNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
263 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
264 TreeMapNode<K, V> leftNode;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
265 if (parent.lefts ().isNotEmpty ())
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
266 leftNode = new RedNode<K,V> (parent.lefts ().getKey (), parent.lefts ().getValue (), parent.lefts ().lefts (), parent.lefts ().rights ()); // check
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
267 else
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
268 leftNode = new EmptyNode<K,V> ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
269 return parent.createNode (parent.getKey (), parent.getValue (), leftNode, this);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
270 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
271 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
272
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
273 protected TreeMapNode<K, V> rebuildFour (TreeMapNode<K, V> parent, Rotate side)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
274 { // case 4
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
275 if (side == Rotate.R) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
276 TreeMapNode<K, V> leftNode = new RedNode<K,V> (parent.lefts ().getKey (), parent.lefts ().getValue (), parent.lefts ().lefts (), parent.lefts ().rights ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
277 return new BlackNode<K,V> (parent.getKey (), parent.getValue (), leftNode, this);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
278 } else {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
279 TreeMapNode<K, V> rightNode = new RedNode<K,V> (parent.rights ().getKey (), parent.rights ().getValue (), parent.rights ().lefts (), parent.rights ().rights ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
280 return new BlackNode<K,V> (parent.getKey (), parent.getValue (), this, rightNode);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
281 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
282 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
283
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
284 protected TreeMapNode<K, V> rebuildfive (TreeMapNode<K, V> parent, Rotate side)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
285 { // case5
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
286 if (side == Rotate.R) { // rotate Left
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
287 TreeMapNode<K, V> leftChild = new RedNode<K,V> (parent.lefts ().getKey (), parent.lefts ().getValue (), parent.lefts ().lefts (), parent.lefts ().rights ().lefts ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
288 TreeMapNode<K, V> rightChild = parent.lefts ().rights ().rights ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
289 TreeMapNode<K, V> leftSubTreeRoot = new BlackNode<K,V> (parent.lefts ().rights ().getKey (), parent.lefts ().rights ().getValue (), leftChild, rightChild);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
290 TreeMapNode<K, V> newParent = parent.createNode (parent.getKey (), parent.getValue (), leftSubTreeRoot, this);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
291 return this.rebuildsix (newParent, Rotate.R);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
292 } else { // rotate Right 修正済み
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
293 TreeMapNode<K, V> leftChild = parent.rights ().lefts ().lefts ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
294 TreeMapNode<K, V> rightChild = new RedNode<K,V> (parent.rights ().getKey (), parent.rights ().getValue (), parent.rights ().lefts ().rights (), parent.rights ().rights ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
295 TreeMapNode<K, V> rightSubTreeRoot = new BlackNode<K,V> (parent.rights ().lefts ().getKey (), parent.rights ().lefts ().getValue (), leftChild, rightChild);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
296 TreeMapNode<K, V> newParent = parent.createNode (parent.getKey (), parent.getValue (), this, rightSubTreeRoot);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
297 return this.rebuildsix (newParent, Rotate.L);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
298 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
299 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
300
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
301 protected TreeMapNode<K, V> rebuildsix (TreeMapNode<K, V> parent, Rotate side)
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
302 { // case6
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
303 if (side == Rotate.L) { // rotate Left
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
304 TreeMapNode<K, V> leftChild = parent.rights ().createNode (parent.getKey (), parent.getValue (), this, parent.rights ().lefts ()); // check
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
305 TreeMapNode<K, V> rightChild = new BlackNode<K,V> (parent.rights ().rights ().getKey (), parent.rights ().rights ().getValue (), parent.rights ().rights ().lefts (), parent.rights ().rights ().rights ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
306 return parent.createNode (parent.rights ().getKey (), parent.rights ().getValue (), leftChild, rightChild);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
307 } else { // rotate Right
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
308 TreeMapNode<K, V> leftChild = new BlackNode<K,V> (parent.lefts ().lefts ().getKey (), parent.lefts ().lefts ().getValue (), parent.lefts ().lefts ().lefts (), parent.lefts ().lefts ().rights ());
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
309 TreeMapNode<K, V> rightChild = parent.lefts ().createNode (parent.getKey (), parent.getValue (), parent.lefts ().rights (), this);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
310 return parent.createNode (parent.lefts ().getKey (), parent.lefts ().getValue (), leftChild, rightChild);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
311 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
312 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
313
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
314
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
315
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
316
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
317
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
318
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
319
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
320
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
321 public abstract bool isNotEmpty ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
322
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
323 public abstract TreeMapNode<K,V> createNode (K key, V value, TreeMapNode<K,V> left, TreeMapNode<K,V> right);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
324
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
325 public abstract TreeMapNode<K,V> insBalance ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
326
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
327
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
328 public abstract Rotate checkRotate (Rotate side);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
329
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
330 public abstract bool isRed ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
331
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
332 public abstract rebuildNode<K,V> replaceNode (TreeMapNode<K,V> parent, Comparer ctr);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
333
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
334 public abstract rebuildNode<K,V> deleteNode ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
335
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
336 // test method
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
337 public abstract int checkDepth (int count, int minCount);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
338 }