1 //===----------------------------------------------------------------------===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9
10 // Not a portable test
11
12 // Returns __tree_next(__z)
13 // template <class _NodePtr>
14 // void
15 // __tree_remove(_NodePtr __root, _NodePtr __z)
16
17 #include <__tree>
18 #include <cassert>
19
20 struct Node
21 {
22 Node* __left_;
23 Node* __right_;
24 Node* __parent_;
25 bool __is_black_;
26
NodeNode27 Node() : __left_(), __right_(), __parent_(), __is_black_() {}
28 };
29
30 void
test1()31 test1()
32 {
33 {
34 // Left
35 // Case 1 -> Case 2 -> x is red turned to black
36 Node root;
37 Node b;
38 Node c;
39 Node d;
40 Node e;
41 Node y;
42
43 root.__left_ = &b;
44
45 b.__parent_ = &root;
46 b.__left_ = &y;
47 b.__right_ = &d;
48 b.__is_black_ = true;
49
50 y.__parent_ = &b;
51 y.__left_ = 0;
52 y.__right_ = 0;
53 y.__is_black_ = true;
54
55 d.__parent_ = &b;
56 d.__left_ = &c;
57 d.__right_ = &e;
58 d.__is_black_ = false;
59
60 c.__parent_ = &d;
61 c.__left_ = 0;
62 c.__right_ = 0;
63 c.__is_black_ = true;
64
65 e.__parent_ = &d;
66 e.__left_ = 0;
67 e.__right_ = 0;
68 e.__is_black_ = true;
69
70 std::__tree_remove(root.__left_, &y);
71 assert(std::__tree_invariant(root.__left_));
72
73 assert(root.__parent_ == 0);
74 assert(root.__left_ == &d);
75 assert(root.__right_ == 0);
76 assert(root.__is_black_ == false);
77
78 assert(d.__parent_ == &root);
79 assert(d.__left_ == &b);
80 assert(d.__right_ == &e);
81 assert(d.__is_black_ == true);
82
83 assert(b.__parent_ == &d);
84 assert(b.__left_ == 0);
85 assert(b.__right_ == &c);
86 assert(b.__is_black_ == true);
87
88 assert(c.__parent_ == &b);
89 assert(c.__left_ == 0);
90 assert(c.__right_ == 0);
91 assert(c.__is_black_ == false);
92
93 assert(e.__parent_ == &d);
94 assert(e.__left_ == 0);
95 assert(e.__right_ == 0);
96 assert(e.__is_black_ == true);
97 }
98 {
99 // Right
100 // Case 1 -> Case 2 -> x is red turned to black
101 Node root;
102 Node b;
103 Node c;
104 Node d;
105 Node e;
106 Node y;
107
108 root.__left_ = &b;
109
110 b.__parent_ = &root;
111 b.__right_ = &y;
112 b.__left_ = &d;
113 b.__is_black_ = true;
114
115 y.__parent_ = &b;
116 y.__right_ = 0;
117 y.__left_ = 0;
118 y.__is_black_ = true;
119
120 d.__parent_ = &b;
121 d.__right_ = &c;
122 d.__left_ = &e;
123 d.__is_black_ = false;
124
125 c.__parent_ = &d;
126 c.__right_ = 0;
127 c.__left_ = 0;
128 c.__is_black_ = true;
129
130 e.__parent_ = &d;
131 e.__right_ = 0;
132 e.__left_ = 0;
133 e.__is_black_ = true;
134
135 std::__tree_remove(root.__left_, &y);
136 assert(std::__tree_invariant(root.__left_));
137
138 assert(root.__parent_ == 0);
139 assert(root.__left_ == &d);
140 assert(root.__right_ == 0);
141 assert(root.__is_black_ == false);
142
143 assert(d.__parent_ == &root);
144 assert(d.__right_ == &b);
145 assert(d.__left_ == &e);
146 assert(d.__is_black_ == true);
147
148 assert(b.__parent_ == &d);
149 assert(b.__right_ == 0);
150 assert(b.__left_ == &c);
151 assert(b.__is_black_ == true);
152
153 assert(c.__parent_ == &b);
154 assert(c.__right_ == 0);
155 assert(c.__left_ == 0);
156 assert(c.__is_black_ == false);
157
158 assert(e.__parent_ == &d);
159 assert(e.__right_ == 0);
160 assert(e.__left_ == 0);
161 assert(e.__is_black_ == true);
162 }
163 {
164 // Left
165 // Case 1 -> Case 3 -> Case 4
166 Node root;
167 Node b;
168 Node c;
169 Node d;
170 Node e;
171 Node f;
172 Node y;
173
174 root.__left_ = &b;
175
176 b.__parent_ = &root;
177 b.__left_ = &y;
178 b.__right_ = &d;
179 b.__is_black_ = true;
180
181 y.__parent_ = &b;
182 y.__left_ = 0;
183 y.__right_ = 0;
184 y.__is_black_ = true;
185
186 d.__parent_ = &b;
187 d.__left_ = &c;
188 d.__right_ = &e;
189 d.__is_black_ = false;
190
191 c.__parent_ = &d;
192 c.__left_ = &f;
193 c.__right_ = 0;
194 c.__is_black_ = true;
195
196 e.__parent_ = &d;
197 e.__left_ = 0;
198 e.__right_ = 0;
199 e.__is_black_ = true;
200
201 f.__parent_ = &c;
202 f.__left_ = 0;
203 f.__right_ = 0;
204 f.__is_black_ = false;
205
206 std::__tree_remove(root.__left_, &y);
207 assert(std::__tree_invariant(root.__left_));
208
209 assert(root.__parent_ == 0);
210 assert(root.__left_ == &d);
211 assert(root.__right_ == 0);
212 assert(root.__is_black_ == false);
213
214 assert(d.__parent_ == &root);
215 assert(d.__left_ == &f);
216 assert(d.__right_ == &e);
217 assert(d.__is_black_ == true);
218
219 assert(f.__parent_ == &d);
220 assert(f.__left_ == &b);
221 assert(f.__right_ == &c);
222 assert(f.__is_black_ == false);
223
224 assert(b.__parent_ == &f);
225 assert(b.__left_ == 0);
226 assert(b.__right_ == 0);
227 assert(b.__is_black_ == true);
228
229 assert(c.__parent_ == &f);
230 assert(c.__left_ == 0);
231 assert(c.__right_ == 0);
232 assert(c.__is_black_ == true);
233
234 assert(e.__parent_ == &d);
235 assert(e.__left_ == 0);
236 assert(e.__right_ == 0);
237 assert(e.__is_black_ == true);
238 }
239 {
240 // Right
241 // Case 1 -> Case 3 -> Case 4
242 Node root;
243 Node b;
244 Node c;
245 Node d;
246 Node e;
247 Node f;
248 Node y;
249
250 root.__left_ = &b;
251
252 b.__parent_ = &root;
253 b.__right_ = &y;
254 b.__left_ = &d;
255 b.__is_black_ = true;
256
257 y.__parent_ = &b;
258 y.__right_ = 0;
259 y.__left_ = 0;
260 y.__is_black_ = true;
261
262 d.__parent_ = &b;
263 d.__right_ = &c;
264 d.__left_ = &e;
265 d.__is_black_ = false;
266
267 c.__parent_ = &d;
268 c.__right_ = &f;
269 c.__left_ = 0;
270 c.__is_black_ = true;
271
272 e.__parent_ = &d;
273 e.__right_ = 0;
274 e.__left_ = 0;
275 e.__is_black_ = true;
276
277 f.__parent_ = &c;
278 f.__right_ = 0;
279 f.__left_ = 0;
280 f.__is_black_ = false;
281
282 std::__tree_remove(root.__left_, &y);
283 assert(std::__tree_invariant(root.__left_));
284
285 assert(root.__parent_ == 0);
286 assert(root.__left_ == &d);
287 assert(root.__right_ == 0);
288 assert(root.__is_black_ == false);
289
290 assert(d.__parent_ == &root);
291 assert(d.__right_ == &f);
292 assert(d.__left_ == &e);
293 assert(d.__is_black_ == true);
294
295 assert(f.__parent_ == &d);
296 assert(f.__right_ == &b);
297 assert(f.__left_ == &c);
298 assert(f.__is_black_ == false);
299
300 assert(b.__parent_ == &f);
301 assert(b.__right_ == 0);
302 assert(b.__left_ == 0);
303 assert(b.__is_black_ == true);
304
305 assert(c.__parent_ == &f);
306 assert(c.__right_ == 0);
307 assert(c.__left_ == 0);
308 assert(c.__is_black_ == true);
309
310 assert(e.__parent_ == &d);
311 assert(e.__right_ == 0);
312 assert(e.__left_ == 0);
313 assert(e.__is_black_ == true);
314 }
315 }
316
317 void
test2()318 test2()
319 {
320 {
321 Node root;
322 Node a;
323 Node b;
324 Node c;
325
326 root.__left_ = &b;
327
328 b.__parent_ = &root;
329 b.__left_ = &a;
330 b.__right_ = &c;
331 b.__is_black_ = true;
332
333 a.__parent_ = &b;
334 a.__left_ = 0;
335 a.__right_ = 0;
336 a.__is_black_ = true;
337
338 c.__parent_ = &b;
339 c.__left_ = 0;
340 c.__right_ = 0;
341 c.__is_black_ = true;
342
343 std::__tree_remove(root.__left_, &a);
344
345 assert(std::__tree_invariant(root.__left_));
346
347 assert(root.__parent_ == 0);
348 assert(root.__left_ == &b);
349 assert(root.__right_ == 0);
350 assert(root.__is_black_ == false);
351
352 assert(b.__parent_ == &root);
353 assert(b.__left_ == 0);
354 assert(b.__right_ == &c);
355 assert(b.__is_black_ == true);
356
357 assert(c.__parent_ == &b);
358 assert(c.__left_ == 0);
359 assert(c.__right_ == 0);
360 assert(c.__is_black_ == false);
361
362 std::__tree_remove(root.__left_, &b);
363
364 assert(std::__tree_invariant(root.__left_));
365
366 assert(root.__parent_ == 0);
367 assert(root.__left_ == &c);
368 assert(root.__right_ == 0);
369 assert(root.__is_black_ == false);
370
371 assert(c.__parent_ == &root);
372 assert(c.__left_ == 0);
373 assert(c.__right_ == 0);
374 assert(c.__is_black_ == true);
375
376 std::__tree_remove(root.__left_, &c);
377
378 assert(std::__tree_invariant(root.__left_));
379
380 assert(root.__parent_ == 0);
381 assert(root.__left_ == 0);
382 assert(root.__right_ == 0);
383 assert(root.__is_black_ == false);
384 }
385 {
386 Node root;
387 Node a;
388 Node b;
389 Node c;
390
391 root.__left_ = &b;
392
393 b.__parent_ = &root;
394 b.__left_ = &a;
395 b.__right_ = &c;
396 b.__is_black_ = true;
397
398 a.__parent_ = &b;
399 a.__left_ = 0;
400 a.__right_ = 0;
401 a.__is_black_ = false;
402
403 c.__parent_ = &b;
404 c.__left_ = 0;
405 c.__right_ = 0;
406 c.__is_black_ = false;
407
408 std::__tree_remove(root.__left_, &a);
409
410 assert(std::__tree_invariant(root.__left_));
411
412 assert(root.__parent_ == 0);
413 assert(root.__left_ == &b);
414 assert(root.__right_ == 0);
415 assert(root.__is_black_ == false);
416
417 assert(b.__parent_ == &root);
418 assert(b.__left_ == 0);
419 assert(b.__right_ == &c);
420 assert(b.__is_black_ == true);
421
422 assert(c.__parent_ == &b);
423 assert(c.__left_ == 0);
424 assert(c.__right_ == 0);
425 assert(c.__is_black_ == false);
426
427 std::__tree_remove(root.__left_, &b);
428
429 assert(std::__tree_invariant(root.__left_));
430
431 assert(root.__parent_ == 0);
432 assert(root.__left_ == &c);
433 assert(root.__right_ == 0);
434 assert(root.__is_black_ == false);
435
436 assert(c.__parent_ == &root);
437 assert(c.__left_ == 0);
438 assert(c.__right_ == 0);
439 assert(c.__is_black_ == true);
440
441 std::__tree_remove(root.__left_, &c);
442
443 assert(std::__tree_invariant(root.__left_));
444
445 assert(root.__parent_ == 0);
446 assert(root.__left_ == 0);
447 assert(root.__right_ == 0);
448 assert(root.__is_black_ == false);
449 }
450 {
451 Node root;
452 Node a;
453 Node b;
454 Node c;
455
456 root.__left_ = &b;
457
458 b.__parent_ = &root;
459 b.__left_ = &a;
460 b.__right_ = &c;
461 b.__is_black_ = true;
462
463 a.__parent_ = &b;
464 a.__left_ = 0;
465 a.__right_ = 0;
466 a.__is_black_ = true;
467
468 c.__parent_ = &b;
469 c.__left_ = 0;
470 c.__right_ = 0;
471 c.__is_black_ = true;
472
473 std::__tree_remove(root.__left_, &a);
474
475 assert(std::__tree_invariant(root.__left_));
476
477 assert(root.__parent_ == 0);
478 assert(root.__left_ == &b);
479 assert(root.__right_ == 0);
480 assert(root.__is_black_ == false);
481
482 assert(b.__parent_ == &root);
483 assert(b.__left_ == 0);
484 assert(b.__right_ == &c);
485 assert(b.__is_black_ == true);
486
487 assert(c.__parent_ == &b);
488 assert(c.__left_ == 0);
489 assert(c.__right_ == 0);
490 assert(c.__is_black_ == false);
491
492 std::__tree_remove(root.__left_, &c);
493
494 assert(std::__tree_invariant(root.__left_));
495
496 assert(root.__parent_ == 0);
497 assert(root.__left_ == &b);
498 assert(root.__right_ == 0);
499 assert(root.__is_black_ == false);
500
501 assert(b.__parent_ == &root);
502 assert(b.__left_ == 0);
503 assert(b.__right_ == 0);
504 assert(b.__is_black_ == true);
505
506 std::__tree_remove(root.__left_, &b);
507
508 assert(std::__tree_invariant(root.__left_));
509
510 assert(root.__parent_ == 0);
511 assert(root.__left_ == 0);
512 assert(root.__right_ == 0);
513 assert(root.__is_black_ == false);
514 }
515 {
516 Node root;
517 Node a;
518 Node b;
519 Node c;
520
521 root.__left_ = &b;
522
523 b.__parent_ = &root;
524 b.__left_ = &a;
525 b.__right_ = &c;
526 b.__is_black_ = true;
527
528 a.__parent_ = &b;
529 a.__left_ = 0;
530 a.__right_ = 0;
531 a.__is_black_ = false;
532
533 c.__parent_ = &b;
534 c.__left_ = 0;
535 c.__right_ = 0;
536 c.__is_black_ = false;
537
538 std::__tree_remove(root.__left_, &a);
539
540 assert(std::__tree_invariant(root.__left_));
541
542 assert(root.__parent_ == 0);
543 assert(root.__left_ == &b);
544 assert(root.__right_ == 0);
545 assert(root.__is_black_ == false);
546
547 assert(b.__parent_ == &root);
548 assert(b.__left_ == 0);
549 assert(b.__right_ == &c);
550 assert(b.__is_black_ == true);
551
552 assert(c.__parent_ == &b);
553 assert(c.__left_ == 0);
554 assert(c.__right_ == 0);
555 assert(c.__is_black_ == false);
556
557 std::__tree_remove(root.__left_, &c);
558
559 assert(std::__tree_invariant(root.__left_));
560
561 assert(root.__parent_ == 0);
562 assert(root.__left_ == &b);
563 assert(root.__right_ == 0);
564 assert(root.__is_black_ == false);
565
566 assert(b.__parent_ == &root);
567 assert(b.__left_ == 0);
568 assert(b.__right_ == 0);
569 assert(b.__is_black_ == true);
570
571 std::__tree_remove(root.__left_, &b);
572
573 assert(std::__tree_invariant(root.__left_));
574
575 assert(root.__parent_ == 0);
576 assert(root.__left_ == 0);
577 assert(root.__right_ == 0);
578 assert(root.__is_black_ == false);
579 }
580 {
581 Node root;
582 Node a;
583 Node b;
584 Node c;
585
586 root.__left_ = &b;
587
588 b.__parent_ = &root;
589 b.__left_ = &a;
590 b.__right_ = &c;
591 b.__is_black_ = true;
592
593 a.__parent_ = &b;
594 a.__left_ = 0;
595 a.__right_ = 0;
596 a.__is_black_ = true;
597
598 c.__parent_ = &b;
599 c.__left_ = 0;
600 c.__right_ = 0;
601 c.__is_black_ = true;
602
603 std::__tree_remove(root.__left_, &b);
604
605 assert(std::__tree_invariant(root.__left_));
606
607 assert(root.__parent_ == 0);
608 assert(root.__left_ == &c);
609 assert(root.__right_ == 0);
610 assert(root.__is_black_ == false);
611
612 assert(a.__parent_ == &c);
613 assert(a.__left_ == 0);
614 assert(a.__right_ == 0);
615 assert(a.__is_black_ == false);
616
617 assert(c.__parent_ == &root);
618 assert(c.__left_ == &a);
619 assert(c.__right_ == 0);
620 assert(c.__is_black_ == true);
621
622 std::__tree_remove(root.__left_, &a);
623
624 assert(std::__tree_invariant(root.__left_));
625
626 assert(root.__parent_ == 0);
627 assert(root.__left_ == &c);
628 assert(root.__right_ == 0);
629 assert(root.__is_black_ == false);
630
631 assert(c.__parent_ == &root);
632 assert(c.__left_ == 0);
633 assert(c.__right_ == 0);
634 assert(c.__is_black_ == true);
635
636 std::__tree_remove(root.__left_, &c);
637
638 assert(std::__tree_invariant(root.__left_));
639
640 assert(root.__parent_ == 0);
641 assert(root.__left_ == 0);
642 assert(root.__right_ == 0);
643 assert(root.__is_black_ == false);
644 }
645 {
646 Node root;
647 Node a;
648 Node b;
649 Node c;
650
651 root.__left_ = &b;
652
653 b.__parent_ = &root;
654 b.__left_ = &a;
655 b.__right_ = &c;
656 b.__is_black_ = true;
657
658 a.__parent_ = &b;
659 a.__left_ = 0;
660 a.__right_ = 0;
661 a.__is_black_ = false;
662
663 c.__parent_ = &b;
664 c.__left_ = 0;
665 c.__right_ = 0;
666 c.__is_black_ = false;
667
668 std::__tree_remove(root.__left_, &b);
669
670 assert(std::__tree_invariant(root.__left_));
671
672 assert(root.__parent_ == 0);
673 assert(root.__left_ == &c);
674 assert(root.__right_ == 0);
675 assert(root.__is_black_ == false);
676
677 assert(a.__parent_ == &c);
678 assert(a.__left_ == 0);
679 assert(a.__right_ == 0);
680 assert(a.__is_black_ == false);
681
682 assert(c.__parent_ == &root);
683 assert(c.__left_ == &a);
684 assert(c.__right_ == 0);
685 assert(c.__is_black_ == true);
686
687 std::__tree_remove(root.__left_, &a);
688
689 assert(std::__tree_invariant(root.__left_));
690
691 assert(root.__parent_ == 0);
692 assert(root.__left_ == &c);
693 assert(root.__right_ == 0);
694 assert(root.__is_black_ == false);
695
696 assert(c.__parent_ == &root);
697 assert(c.__left_ == 0);
698 assert(c.__right_ == 0);
699 assert(c.__is_black_ == true);
700
701 std::__tree_remove(root.__left_, &c);
702
703 assert(std::__tree_invariant(root.__left_));
704
705 assert(root.__parent_ == 0);
706 assert(root.__left_ == 0);
707 assert(root.__right_ == 0);
708 assert(root.__is_black_ == false);
709 }
710 {
711 Node root;
712 Node a;
713 Node b;
714 Node c;
715
716 root.__left_ = &b;
717
718 b.__parent_ = &root;
719 b.__left_ = &a;
720 b.__right_ = &c;
721 b.__is_black_ = true;
722
723 a.__parent_ = &b;
724 a.__left_ = 0;
725 a.__right_ = 0;
726 a.__is_black_ = true;
727
728 c.__parent_ = &b;
729 c.__left_ = 0;
730 c.__right_ = 0;
731 c.__is_black_ = true;
732
733 std::__tree_remove(root.__left_, &b);
734
735 assert(std::__tree_invariant(root.__left_));
736
737 assert(root.__parent_ == 0);
738 assert(root.__left_ == &c);
739 assert(root.__right_ == 0);
740 assert(root.__is_black_ == false);
741
742 assert(a.__parent_ == &c);
743 assert(a.__left_ == 0);
744 assert(a.__right_ == 0);
745 assert(a.__is_black_ == false);
746
747 assert(c.__parent_ == &root);
748 assert(c.__left_ == &a);
749 assert(c.__right_ == 0);
750 assert(c.__is_black_ == true);
751
752 std::__tree_remove(root.__left_, &c);
753
754 assert(std::__tree_invariant(root.__left_));
755
756 assert(root.__parent_ == 0);
757 assert(root.__left_ == &a);
758 assert(root.__right_ == 0);
759 assert(root.__is_black_ == false);
760
761 assert(a.__parent_ == &root);
762 assert(a.__left_ == 0);
763 assert(a.__right_ == 0);
764 assert(a.__is_black_ == true);
765
766 std::__tree_remove(root.__left_, &a);
767
768 assert(std::__tree_invariant(root.__left_));
769
770 assert(root.__parent_ == 0);
771 assert(root.__left_ == 0);
772 assert(root.__right_ == 0);
773 assert(root.__is_black_ == false);
774 }
775 {
776 Node root;
777 Node a;
778 Node b;
779 Node c;
780
781 root.__left_ = &b;
782
783 b.__parent_ = &root;
784 b.__left_ = &a;
785 b.__right_ = &c;
786 b.__is_black_ = true;
787
788 a.__parent_ = &b;
789 a.__left_ = 0;
790 a.__right_ = 0;
791 a.__is_black_ = false;
792
793 c.__parent_ = &b;
794 c.__left_ = 0;
795 c.__right_ = 0;
796 c.__is_black_ = false;
797
798 std::__tree_remove(root.__left_, &b);
799
800 assert(std::__tree_invariant(root.__left_));
801
802 assert(root.__parent_ == 0);
803 assert(root.__left_ == &c);
804 assert(root.__right_ == 0);
805 assert(root.__is_black_ == false);
806
807 assert(a.__parent_ == &c);
808 assert(a.__left_ == 0);
809 assert(a.__right_ == 0);
810 assert(a.__is_black_ == false);
811
812 assert(c.__parent_ == &root);
813 assert(c.__left_ == &a);
814 assert(c.__right_ == 0);
815 assert(c.__is_black_ == true);
816
817 std::__tree_remove(root.__left_, &c);
818
819 assert(std::__tree_invariant(root.__left_));
820
821 assert(root.__parent_ == 0);
822 assert(root.__left_ == &a);
823 assert(root.__right_ == 0);
824 assert(root.__is_black_ == false);
825
826 assert(a.__parent_ == &root);
827 assert(a.__left_ == 0);
828 assert(a.__right_ == 0);
829 assert(a.__is_black_ == true);
830
831 std::__tree_remove(root.__left_, &a);
832
833 assert(std::__tree_invariant(root.__left_));
834
835 assert(root.__parent_ == 0);
836 assert(root.__left_ == 0);
837 assert(root.__right_ == 0);
838 assert(root.__is_black_ == false);
839 }
840 {
841 Node root;
842 Node a;
843 Node b;
844 Node c;
845
846 root.__left_ = &b;
847
848 b.__parent_ = &root;
849 b.__left_ = &a;
850 b.__right_ = &c;
851 b.__is_black_ = true;
852
853 a.__parent_ = &b;
854 a.__left_ = 0;
855 a.__right_ = 0;
856 a.__is_black_ = true;
857
858 c.__parent_ = &b;
859 c.__left_ = 0;
860 c.__right_ = 0;
861 c.__is_black_ = true;
862
863 std::__tree_remove(root.__left_, &c);
864
865 assert(std::__tree_invariant(root.__left_));
866
867 assert(root.__parent_ == 0);
868 assert(root.__left_ == &b);
869 assert(root.__right_ == 0);
870 assert(root.__is_black_ == false);
871
872 assert(a.__parent_ == &b);
873 assert(a.__left_ == 0);
874 assert(a.__right_ == 0);
875 assert(a.__is_black_ == false);
876
877 assert(b.__parent_ == &root);
878 assert(b.__left_ == &a);
879 assert(b.__right_ == 0);
880 assert(b.__is_black_ == true);
881
882 std::__tree_remove(root.__left_, &b);
883
884 assert(std::__tree_invariant(root.__left_));
885
886 assert(root.__parent_ == 0);
887 assert(root.__left_ == &a);
888 assert(root.__right_ == 0);
889 assert(root.__is_black_ == false);
890
891 assert(a.__parent_ == &root);
892 assert(a.__left_ == 0);
893 assert(a.__right_ == 0);
894 assert(a.__is_black_ == true);
895
896 std::__tree_remove(root.__left_, &a);
897
898 assert(std::__tree_invariant(root.__left_));
899
900 assert(root.__parent_ == 0);
901 assert(root.__left_ == 0);
902 assert(root.__right_ == 0);
903 assert(root.__is_black_ == false);
904 }
905 {
906 Node root;
907 Node a;
908 Node b;
909 Node c;
910
911 root.__left_ = &b;
912
913 b.__parent_ = &root;
914 b.__left_ = &a;
915 b.__right_ = &c;
916 b.__is_black_ = true;
917
918 a.__parent_ = &b;
919 a.__left_ = 0;
920 a.__right_ = 0;
921 a.__is_black_ = false;
922
923 c.__parent_ = &b;
924 c.__left_ = 0;
925 c.__right_ = 0;
926 c.__is_black_ = false;
927
928 std::__tree_remove(root.__left_, &c);
929
930 assert(std::__tree_invariant(root.__left_));
931
932 assert(root.__parent_ == 0);
933 assert(root.__left_ == &b);
934 assert(root.__right_ == 0);
935 assert(root.__is_black_ == false);
936
937 assert(a.__parent_ == &b);
938 assert(a.__left_ == 0);
939 assert(a.__right_ == 0);
940 assert(a.__is_black_ == false);
941
942 assert(b.__parent_ == &root);
943 assert(b.__left_ == &a);
944 assert(b.__right_ == 0);
945 assert(b.__is_black_ == true);
946
947 std::__tree_remove(root.__left_, &b);
948
949 assert(std::__tree_invariant(root.__left_));
950
951 assert(root.__parent_ == 0);
952 assert(root.__left_ == &a);
953 assert(root.__right_ == 0);
954 assert(root.__is_black_ == false);
955
956 assert(a.__parent_ == &root);
957 assert(a.__left_ == 0);
958 assert(a.__right_ == 0);
959 assert(a.__is_black_ == true);
960
961 std::__tree_remove(root.__left_, &a);
962
963 assert(std::__tree_invariant(root.__left_));
964
965 assert(root.__parent_ == 0);
966 assert(root.__left_ == 0);
967 assert(root.__right_ == 0);
968 assert(root.__is_black_ == false);
969 }
970 {
971 Node root;
972 Node a;
973 Node b;
974 Node c;
975
976 root.__left_ = &b;
977
978 b.__parent_ = &root;
979 b.__left_ = &a;
980 b.__right_ = &c;
981 b.__is_black_ = true;
982
983 a.__parent_ = &b;
984 a.__left_ = 0;
985 a.__right_ = 0;
986 a.__is_black_ = true;
987
988 c.__parent_ = &b;
989 c.__left_ = 0;
990 c.__right_ = 0;
991 c.__is_black_ = true;
992
993 std::__tree_remove(root.__left_, &c);
994
995 assert(std::__tree_invariant(root.__left_));
996
997 assert(root.__parent_ == 0);
998 assert(root.__left_ == &b);
999 assert(root.__right_ == 0);
1000 assert(root.__is_black_ == false);
1001
1002 assert(a.__parent_ == &b);
1003 assert(a.__left_ == 0);
1004 assert(a.__right_ == 0);
1005 assert(a.__is_black_ == false);
1006
1007 assert(b.__parent_ == &root);
1008 assert(b.__left_ == &a);
1009 assert(b.__right_ == 0);
1010 assert(b.__is_black_ == true);
1011
1012 std::__tree_remove(root.__left_, &a);
1013
1014 assert(std::__tree_invariant(root.__left_));
1015
1016 assert(root.__parent_ == 0);
1017 assert(root.__left_ == &b);
1018 assert(root.__right_ == 0);
1019 assert(root.__is_black_ == false);
1020
1021 assert(b.__parent_ == &root);
1022 assert(b.__left_ == 0);
1023 assert(b.__right_ == 0);
1024 assert(b.__is_black_ == true);
1025
1026 std::__tree_remove(root.__left_, &b);
1027
1028 assert(std::__tree_invariant(root.__left_));
1029
1030 assert(root.__parent_ == 0);
1031 assert(root.__left_ == 0);
1032 assert(root.__right_ == 0);
1033 assert(root.__is_black_ == false);
1034 }
1035 {
1036 Node root;
1037 Node a;
1038 Node b;
1039 Node c;
1040
1041 root.__left_ = &b;
1042
1043 b.__parent_ = &root;
1044 b.__left_ = &a;
1045 b.__right_ = &c;
1046 b.__is_black_ = true;
1047
1048 a.__parent_ = &b;
1049 a.__left_ = 0;
1050 a.__right_ = 0;
1051 a.__is_black_ = false;
1052
1053 c.__parent_ = &b;
1054 c.__left_ = 0;
1055 c.__right_ = 0;
1056 c.__is_black_ = false;
1057
1058 std::__tree_remove(root.__left_, &c);
1059
1060 assert(std::__tree_invariant(root.__left_));
1061
1062 assert(root.__parent_ == 0);
1063 assert(root.__left_ == &b);
1064 assert(root.__right_ == 0);
1065 assert(root.__is_black_ == false);
1066
1067 assert(a.__parent_ == &b);
1068 assert(a.__left_ == 0);
1069 assert(a.__right_ == 0);
1070 assert(a.__is_black_ == false);
1071
1072 assert(b.__parent_ == &root);
1073 assert(b.__left_ == &a);
1074 assert(b.__right_ == 0);
1075 assert(b.__is_black_ == true);
1076
1077 std::__tree_remove(root.__left_, &a);
1078
1079 assert(std::__tree_invariant(root.__left_));
1080
1081 assert(root.__parent_ == 0);
1082 assert(root.__left_ == &b);
1083 assert(root.__right_ == 0);
1084 assert(root.__is_black_ == false);
1085
1086 assert(b.__parent_ == &root);
1087 assert(b.__left_ == 0);
1088 assert(b.__right_ == 0);
1089 assert(b.__is_black_ == true);
1090
1091 std::__tree_remove(root.__left_, &b);
1092
1093 assert(std::__tree_invariant(root.__left_));
1094
1095 assert(root.__parent_ == 0);
1096 assert(root.__left_ == 0);
1097 assert(root.__right_ == 0);
1098 assert(root.__is_black_ == false);
1099 }
1100 }
1101
1102 void
test3()1103 test3()
1104 {
1105 Node root;
1106 Node a;
1107 Node b;
1108 Node c;
1109 Node d;
1110 Node e;
1111 Node f;
1112 Node g;
1113 Node h;
1114
1115 root.__left_ = &e;
1116
1117 e.__parent_ = &root;
1118 e.__left_ = &c;
1119 e.__right_ = &g;
1120 e.__is_black_ = true;
1121
1122 c.__parent_ = &e;
1123 c.__left_ = &b;
1124 c.__right_ = &d;
1125 c.__is_black_ = false;
1126
1127 g.__parent_ = &e;
1128 g.__left_ = &f;
1129 g.__right_ = &h;
1130 g.__is_black_ = false;
1131
1132 b.__parent_ = &c;
1133 b.__left_ = &a;
1134 b.__right_ = 0;
1135 b.__is_black_ = true;
1136
1137 d.__parent_ = &c;
1138 d.__left_ = 0;
1139 d.__right_ = 0;
1140 d.__is_black_ = true;
1141
1142 f.__parent_ = &g;
1143 f.__left_ = 0;
1144 f.__right_ = 0;
1145 f.__is_black_ = true;
1146
1147 h.__parent_ = &g;
1148 h.__left_ = 0;
1149 h.__right_ = 0;
1150 h.__is_black_ = true;
1151
1152 a.__parent_ = &b;
1153 a.__left_ = 0;
1154 a.__right_ = 0;
1155 a.__is_black_ = false;
1156
1157 assert(std::__tree_invariant(root.__left_));
1158
1159 std::__tree_remove(root.__left_, &h);
1160
1161 assert(std::__tree_invariant(root.__left_));
1162
1163 assert(root.__parent_ == 0);
1164 assert(root.__left_ == &e);
1165 assert(root.__right_ == 0);
1166 assert(root.__is_black_ == false);
1167
1168 assert(e.__parent_ == &root);
1169 assert(e.__left_ == &c);
1170 assert(e.__right_ == &g);
1171 assert(e.__is_black_ == true);
1172
1173 assert(c.__parent_ == &e);
1174 assert(c.__left_ == &b);
1175 assert(c.__right_ == &d);
1176 assert(c.__is_black_ == false);
1177
1178 assert(g.__parent_ == &e);
1179 assert(g.__left_ == &f);
1180 assert(g.__right_ == 0);
1181 assert(g.__is_black_ == true);
1182
1183 assert(b.__parent_ == &c);
1184 assert(b.__left_ == &a);
1185 assert(b.__right_ == 0);
1186 assert(b.__is_black_ == true);
1187
1188 assert(a.__parent_ == &b);
1189 assert(a.__left_ == 0);
1190 assert(a.__right_ == 0);
1191 assert(a.__is_black_ == false);
1192
1193 assert(d.__parent_ == &c);
1194 assert(d.__left_ == 0);
1195 assert(d.__right_ == 0);
1196 assert(d.__is_black_ == true);
1197
1198 assert(f.__parent_ == &g);
1199 assert(f.__left_ == 0);
1200 assert(f.__right_ == 0);
1201 assert(f.__is_black_ == false);
1202
1203 std::__tree_remove(root.__left_, &g);
1204
1205 assert(std::__tree_invariant(root.__left_));
1206
1207 assert(root.__parent_ == 0);
1208 assert(root.__left_ == &e);
1209 assert(root.__right_ == 0);
1210 assert(root.__is_black_ == false);
1211
1212 assert(e.__parent_ == &root);
1213 assert(e.__left_ == &c);
1214 assert(e.__right_ == &f);
1215 assert(e.__is_black_ == true);
1216
1217 assert(c.__parent_ == &e);
1218 assert(c.__left_ == &b);
1219 assert(c.__right_ == &d);
1220 assert(c.__is_black_ == false);
1221
1222 assert(b.__parent_ == &c);
1223 assert(b.__left_ == &a);
1224 assert(b.__right_ == 0);
1225 assert(b.__is_black_ == true);
1226
1227 assert(a.__parent_ == &b);
1228 assert(a.__left_ == 0);
1229 assert(a.__right_ == 0);
1230 assert(a.__is_black_ == false);
1231
1232 assert(d.__parent_ == &c);
1233 assert(d.__left_ == 0);
1234 assert(d.__right_ == 0);
1235 assert(d.__is_black_ == true);
1236
1237 assert(f.__parent_ == &e);
1238 assert(f.__left_ == 0);
1239 assert(f.__right_ == 0);
1240 assert(f.__is_black_ == true);
1241
1242 std::__tree_remove(root.__left_, &f);
1243
1244 assert(std::__tree_invariant(root.__left_));
1245
1246 assert(root.__parent_ == 0);
1247 assert(root.__left_ == &c);
1248 assert(root.__right_ == 0);
1249 assert(root.__is_black_ == false);
1250
1251 assert(c.__parent_ == &root);
1252 assert(c.__left_ == &b);
1253 assert(c.__right_ == &e);
1254 assert(c.__is_black_ == true);
1255
1256 assert(b.__parent_ == &c);
1257 assert(b.__left_ == &a);
1258 assert(b.__right_ == 0);
1259 assert(b.__is_black_ == true);
1260
1261 assert(e.__parent_ == &c);
1262 assert(e.__left_ == &d);
1263 assert(e.__right_ == 0);
1264 assert(e.__is_black_ == true);
1265
1266 assert(a.__parent_ == &b);
1267 assert(a.__left_ == 0);
1268 assert(a.__right_ == 0);
1269 assert(a.__is_black_ == false);
1270
1271 assert(d.__parent_ == &e);
1272 assert(d.__left_ == 0);
1273 assert(d.__right_ == 0);
1274 assert(d.__is_black_ == false);
1275
1276 std::__tree_remove(root.__left_, &e);
1277
1278 assert(std::__tree_invariant(root.__left_));
1279
1280 assert(root.__parent_ == 0);
1281 assert(root.__left_ == &c);
1282 assert(root.__right_ == 0);
1283 assert(root.__is_black_ == false);
1284
1285 assert(c.__parent_ == &root);
1286 assert(c.__left_ == &b);
1287 assert(c.__right_ == &d);
1288 assert(c.__is_black_ == true);
1289
1290 assert(b.__parent_ == &c);
1291 assert(b.__left_ == &a);
1292 assert(b.__right_ == 0);
1293 assert(b.__is_black_ == true);
1294
1295 assert(a.__parent_ == &b);
1296 assert(a.__left_ == 0);
1297 assert(a.__right_ == 0);
1298 assert(a.__is_black_ == false);
1299
1300 assert(d.__parent_ == &c);
1301 assert(d.__left_ == 0);
1302 assert(d.__right_ == 0);
1303 assert(d.__is_black_ == true);
1304
1305 std::__tree_remove(root.__left_, &d);
1306
1307 assert(std::__tree_invariant(root.__left_));
1308
1309 assert(root.__parent_ == 0);
1310 assert(root.__left_ == &b);
1311 assert(root.__right_ == 0);
1312 assert(root.__is_black_ == false);
1313
1314 assert(b.__parent_ == &root);
1315 assert(b.__left_ == &a);
1316 assert(b.__right_ == &c);
1317 assert(b.__is_black_ == true);
1318
1319 assert(a.__parent_ == &b);
1320 assert(a.__left_ == 0);
1321 assert(a.__right_ == 0);
1322 assert(a.__is_black_ == true);
1323
1324 assert(c.__parent_ == &b);
1325 assert(c.__left_ == 0);
1326 assert(c.__right_ == 0);
1327 assert(c.__is_black_ == true);
1328
1329 std::__tree_remove(root.__left_, &c);
1330
1331 assert(std::__tree_invariant(root.__left_));
1332
1333 assert(root.__parent_ == 0);
1334 assert(root.__left_ == &b);
1335 assert(root.__right_ == 0);
1336 assert(root.__is_black_ == false);
1337
1338 assert(b.__parent_ == &root);
1339 assert(b.__left_ == &a);
1340 assert(b.__right_ == 0);
1341 assert(b.__is_black_ == true);
1342
1343 assert(a.__parent_ == &b);
1344 assert(a.__left_ == 0);
1345 assert(a.__right_ == 0);
1346 assert(a.__is_black_ == false);
1347
1348 std::__tree_remove(root.__left_, &b);
1349
1350 assert(std::__tree_invariant(root.__left_));
1351
1352 assert(root.__parent_ == 0);
1353 assert(root.__left_ == &a);
1354 assert(root.__right_ == 0);
1355 assert(root.__is_black_ == false);
1356
1357 assert(a.__parent_ == &root);
1358 assert(a.__left_ == 0);
1359 assert(a.__right_ == 0);
1360 assert(a.__is_black_ == true);
1361
1362 std::__tree_remove(root.__left_, &a);
1363
1364 assert(std::__tree_invariant(root.__left_));
1365
1366 assert(root.__parent_ == 0);
1367 assert(root.__left_ == 0);
1368 assert(root.__right_ == 0);
1369 assert(root.__is_black_ == false);
1370 }
1371
1372 void
test4()1373 test4()
1374 {
1375 Node root;
1376 Node a;
1377 Node b;
1378 Node c;
1379 Node d;
1380 Node e;
1381 Node f;
1382 Node g;
1383 Node h;
1384
1385 root.__left_ = &d;
1386
1387 d.__parent_ = &root;
1388 d.__left_ = &b;
1389 d.__right_ = &f;
1390 d.__is_black_ = true;
1391
1392 b.__parent_ = &d;
1393 b.__left_ = &a;
1394 b.__right_ = &c;
1395 b.__is_black_ = false;
1396
1397 f.__parent_ = &d;
1398 f.__left_ = &e;
1399 f.__right_ = &g;
1400 f.__is_black_ = false;
1401
1402 a.__parent_ = &b;
1403 a.__left_ = 0;
1404 a.__right_ = 0;
1405 a.__is_black_ = true;
1406
1407 c.__parent_ = &b;
1408 c.__left_ = 0;
1409 c.__right_ = 0;
1410 c.__is_black_ = true;
1411
1412 e.__parent_ = &f;
1413 e.__left_ = 0;
1414 e.__right_ = 0;
1415 e.__is_black_ = true;
1416
1417 g.__parent_ = &f;
1418 g.__left_ = 0;
1419 g.__right_ = &h;
1420 g.__is_black_ = true;
1421
1422 h.__parent_ = &g;
1423 h.__left_ = 0;
1424 h.__right_ = 0;
1425 h.__is_black_ = false;
1426
1427 assert(std::__tree_invariant(root.__left_));
1428
1429 std::__tree_remove(root.__left_, &a);
1430
1431 assert(std::__tree_invariant(root.__left_));
1432
1433 assert(root.__parent_ == 0);
1434 assert(root.__left_ == &d);
1435 assert(root.__right_ == 0);
1436 assert(root.__is_black_ == false);
1437
1438 assert(d.__parent_ == &root);
1439 assert(d.__left_ == &b);
1440 assert(d.__right_ == &f);
1441 assert(d.__is_black_ == true);
1442
1443 assert(b.__parent_ == &d);
1444 assert(b.__left_ == 0);
1445 assert(b.__right_ == &c);
1446 assert(b.__is_black_ == true);
1447
1448 assert(f.__parent_ == &d);
1449 assert(f.__left_ == &e);
1450 assert(f.__right_ == &g);
1451 assert(f.__is_black_ == false);
1452
1453 assert(c.__parent_ == &b);
1454 assert(c.__left_ == 0);
1455 assert(c.__right_ == 0);
1456 assert(c.__is_black_ == false);
1457
1458 assert(e.__parent_ == &f);
1459 assert(e.__left_ == 0);
1460 assert(e.__right_ == 0);
1461 assert(e.__is_black_ == true);
1462
1463 assert(g.__parent_ == &f);
1464 assert(g.__left_ == 0);
1465 assert(g.__right_ == &h);
1466 assert(g.__is_black_ == true);
1467
1468 assert(h.__parent_ == &g);
1469 assert(h.__left_ == 0);
1470 assert(h.__right_ == 0);
1471 assert(h.__is_black_ == false);
1472
1473 std::__tree_remove(root.__left_, &b);
1474
1475 assert(std::__tree_invariant(root.__left_));
1476
1477 assert(root.__parent_ == 0);
1478 assert(root.__left_ == &d);
1479 assert(root.__right_ == 0);
1480 assert(root.__is_black_ == false);
1481
1482 assert(d.__parent_ == &root);
1483 assert(d.__left_ == &c);
1484 assert(d.__right_ == &f);
1485 assert(d.__is_black_ == true);
1486
1487 assert(c.__parent_ == &d);
1488 assert(c.__left_ == 0);
1489 assert(c.__right_ == 0);
1490 assert(c.__is_black_ == true);
1491
1492 assert(f.__parent_ == &d);
1493 assert(f.__left_ == &e);
1494 assert(f.__right_ == &g);
1495 assert(f.__is_black_ == false);
1496
1497 assert(e.__parent_ == &f);
1498 assert(e.__left_ == 0);
1499 assert(e.__right_ == 0);
1500 assert(e.__is_black_ == true);
1501
1502 assert(g.__parent_ == &f);
1503 assert(g.__left_ == 0);
1504 assert(g.__right_ == &h);
1505 assert(g.__is_black_ == true);
1506
1507 assert(h.__parent_ == &g);
1508 assert(h.__left_ == 0);
1509 assert(h.__right_ == 0);
1510 assert(h.__is_black_ == false);
1511
1512 std::__tree_remove(root.__left_, &c);
1513
1514 assert(std::__tree_invariant(root.__left_));
1515
1516 assert(root.__parent_ == 0);
1517 assert(root.__left_ == &f);
1518 assert(root.__right_ == 0);
1519 assert(root.__is_black_ == false);
1520
1521 assert(f.__parent_ == &root);
1522 assert(f.__left_ == &d);
1523 assert(f.__right_ == &g);
1524 assert(f.__is_black_ == true);
1525
1526 assert(d.__parent_ == &f);
1527 assert(d.__left_ == 0);
1528 assert(d.__right_ == &e);
1529 assert(d.__is_black_ == true);
1530
1531 assert(g.__parent_ == &f);
1532 assert(g.__left_ == 0);
1533 assert(g.__right_ == &h);
1534 assert(g.__is_black_ == true);
1535
1536 assert(e.__parent_ == &d);
1537 assert(e.__left_ == 0);
1538 assert(e.__right_ == 0);
1539 assert(e.__is_black_ == false);
1540
1541 assert(h.__parent_ == &g);
1542 assert(h.__left_ == 0);
1543 assert(h.__right_ == 0);
1544 assert(h.__is_black_ == false);
1545
1546 std::__tree_remove(root.__left_, &d);
1547
1548 assert(std::__tree_invariant(root.__left_));
1549
1550 assert(root.__parent_ == 0);
1551 assert(root.__left_ == &f);
1552 assert(root.__right_ == 0);
1553 assert(root.__is_black_ == false);
1554
1555 assert(f.__parent_ == &root);
1556 assert(f.__left_ == &e);
1557 assert(f.__right_ == &g);
1558 assert(f.__is_black_ == true);
1559
1560 assert(e.__parent_ == &f);
1561 assert(e.__left_ == 0);
1562 assert(e.__right_ == 0);
1563 assert(e.__is_black_ == true);
1564
1565 assert(g.__parent_ == &f);
1566 assert(g.__left_ == 0);
1567 assert(g.__right_ == &h);
1568 assert(g.__is_black_ == true);
1569
1570 assert(h.__parent_ == &g);
1571 assert(h.__left_ == 0);
1572 assert(h.__right_ == 0);
1573 assert(h.__is_black_ == false);
1574
1575 std::__tree_remove(root.__left_, &e);
1576
1577 assert(std::__tree_invariant(root.__left_));
1578
1579 assert(root.__parent_ == 0);
1580 assert(root.__left_ == &g);
1581 assert(root.__right_ == 0);
1582 assert(root.__is_black_ == false);
1583
1584 assert(g.__parent_ == &root);
1585 assert(g.__left_ == &f);
1586 assert(g.__right_ == &h);
1587 assert(g.__is_black_ == true);
1588
1589 assert(f.__parent_ == &g);
1590 assert(f.__left_ == 0);
1591 assert(f.__right_ == 0);
1592 assert(f.__is_black_ == true);
1593
1594 assert(h.__parent_ == &g);
1595 assert(h.__left_ == 0);
1596 assert(h.__right_ == 0);
1597 assert(h.__is_black_ == true);
1598
1599 std::__tree_remove(root.__left_, &f);
1600
1601 assert(std::__tree_invariant(root.__left_));
1602
1603 assert(root.__parent_ == 0);
1604 assert(root.__left_ == &g);
1605 assert(root.__right_ == 0);
1606 assert(root.__is_black_ == false);
1607
1608 assert(g.__parent_ == &root);
1609 assert(g.__left_ == 0);
1610 assert(g.__right_ == &h);
1611 assert(g.__is_black_ == true);
1612
1613 assert(h.__parent_ == &g);
1614 assert(h.__left_ == 0);
1615 assert(h.__right_ == 0);
1616 assert(h.__is_black_ == false);
1617
1618 std::__tree_remove(root.__left_, &g);
1619
1620 assert(std::__tree_invariant(root.__left_));
1621
1622 assert(root.__parent_ == 0);
1623 assert(root.__left_ == &h);
1624 assert(root.__right_ == 0);
1625 assert(root.__is_black_ == false);
1626
1627 assert(h.__parent_ == &root);
1628 assert(h.__left_ == 0);
1629 assert(h.__right_ == 0);
1630 assert(h.__is_black_ == true);
1631
1632 std::__tree_remove(root.__left_, &h);
1633
1634 assert(std::__tree_invariant(root.__left_));
1635
1636 assert(root.__parent_ == 0);
1637 assert(root.__left_ == 0);
1638 assert(root.__right_ == 0);
1639 assert(root.__is_black_ == false);
1640 }
1641
main()1642 int main()
1643 {
1644 test1();
1645 test2();
1646 test3();
1647 test4();
1648 }
1649