SplayTree-inl.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. #include <stdexcept>
  2. #include "library/arrayQueue.h"
  3. /*SplayTreeNode implmentation */
  4. //default constructor
  5. template <typename K, typename V>
  6. SplayTreeNode<K,V>::SplayTreeNode() {
  7. height = - 1;
  8. parent = NULL;
  9. left = NULL;
  10. right = NULL;
  11. }
  12. // standard constructor
  13. template <typename K, typename V>
  14. SplayTreeNode<K,V>::SplayTreeNode(K k, V v) {
  15. height = 0;
  16. key = k;
  17. value = v;
  18. parent = NULL;
  19. left = NULL;
  20. right = NULL;
  21. }
  22. /*SplayTree Implemenation */
  23. //standard constructor
  24. template <typename K, typename V>
  25. SplayTree<K,V>::SplayTree() {
  26. size = 0;
  27. root = NULL;
  28. }
  29. template <typename K, typename V>
  30. SplayTree<K,V>::~SplayTree() {
  31. traverseAndDelete(root);
  32. }
  33. template <typename K, typename V>
  34. int SplayTree<K,V>::getSize() {
  35. return size;
  36. }
  37. template <typename K, typename V>
  38. bool SplayTree<K,V>::isEmpty() {
  39. return size == 0;
  40. }
  41. template <typename K, typename V>
  42. K SplayTree<K,V>::getMax() {
  43. if (isEmpty()) {
  44. throw std::runtime_error("SplayTree::getMax called on an empty tree.");
  45. }
  46. return getMaxInSubtree(root);
  47. }
  48. template <typename K, typename V>
  49. K SplayTree<K,V>::getMin() {
  50. if (isEmpty()) {
  51. throw std::runtime_error("SplayTree::getMin called on an empty tree.");
  52. }
  53. return getMinInSubtree(root);
  54. }
  55. template <typename K, typename V>
  56. int SplayTree<K,V>::getHeight() {
  57. if (root == NULL)
  58. return -1;
  59. else
  60. return root->height;
  61. }
  62. template <typename K, typename V>
  63. void SplayTree<K,V>::insert(K key, V value) {
  64. root = insertInSubtree(root, key, value);
  65. }
  66. template <typename K, typename V>
  67. void SplayTree<K,V>::update(K key, V value) {
  68. updateInSubtree(root, key, value);
  69. }
  70. template <typename K, typename V>
  71. bool SplayTree<K,V>::contains(K key) {
  72. return containsInSubtree(root, key);
  73. }
  74. template <typename K, typename V>
  75. void SplayTree<K,V>::remove(K key) {
  76. root = removeFromSubtree(root, key);
  77. }
  78. template <typename K, typename V>
  79. V SplayTree<K,V>::find(K key) {
  80. return findInSubtree(root, key);
  81. }
  82. template <typename K, typename V>
  83. Queue< Pair<K,V> >* SplayTree<K,V>::getPreOrder() {
  84. Queue< Pair<K,V> >* it = new ArrayQueue< Pair<K,V> >();
  85. buildPreOrder(root, it);
  86. return it;
  87. }
  88. template <typename K, typename V>
  89. Queue< Pair<K,V> >* SplayTree<K,V>::getInOrder() {
  90. Queue< Pair<K,V> >* it = new ArrayQueue< Pair<K,V> >();
  91. buildInOrder(root, it);
  92. return it;
  93. }
  94. template <typename K, typename V>
  95. Queue< Pair<K,V> >* SplayTree<K,V>::getPostOrder() {
  96. Queue< Pair<K,V> >* it = new ArrayQueue< Pair<K,V> >();
  97. buildPostOrder(root, it);
  98. return it;
  99. }
  100. template <typename K, typename V>
  101. Queue< Pair<K,V> >* SplayTree<K,V>::getLevelOrder() {
  102. ArrayQueue< SplayTreeNode<K,V>* > levelQ;
  103. Queue< Pair<K,V> >* it = new ArrayQueue< Pair<K,V> >();
  104. levelQ.enqueue(root);
  105. while (!levelQ.isEmpty()) {
  106. SplayTreeNode<K,V>* current = levelQ.dequeue();
  107. if (current != NULL) {
  108. it->enqueue( Pair<K,V>(current->key, current->value) );
  109. levelQ.enqueue(current->left);
  110. levelQ.enqueue(current->right);
  111. }
  112. }
  113. return it;
  114. }