data-structure-typed 1.41.5 → 1.41.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (774) hide show
  1. package/CHANGELOG.md +1 -1
  2. package/README.md +15 -535
  3. package/benchmark/report.html +14 -12
  4. package/benchmark/report.json +117 -117
  5. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/avl-tree.d.ts +1 -1
  6. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/avl-tree.js +2 -2
  7. package/dist/cjs/src/data-structures/binary-tree/avl-tree.js.map +1 -0
  8. package/dist/cjs/src/data-structures/binary-tree/binary-indexed-tree.js.map +1 -0
  9. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/binary-tree.d.ts +4 -3
  10. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/binary-tree.js +19 -18
  11. package/dist/cjs/src/data-structures/binary-tree/binary-tree.js.map +1 -0
  12. package/dist/{mjs → cjs/src}/data-structures/binary-tree/bst.d.ts +1 -20
  13. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/bst.js +5 -27
  14. package/dist/cjs/src/data-structures/binary-tree/bst.js.map +1 -0
  15. package/dist/cjs/src/data-structures/binary-tree/index.js.map +1 -0
  16. package/dist/cjs/src/data-structures/binary-tree/rb-tree.js.map +1 -0
  17. package/dist/cjs/src/data-structures/binary-tree/segment-tree.js.map +1 -0
  18. package/dist/{mjs → cjs/src}/data-structures/binary-tree/tree-multiset.d.ts +1 -1
  19. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/tree-multiset.js +2 -2
  20. package/dist/cjs/src/data-structures/binary-tree/tree-multiset.js.map +1 -0
  21. package/dist/cjs/src/data-structures/graph/abstract-graph.js.map +1 -0
  22. package/dist/cjs/src/data-structures/graph/directed-graph.js.map +1 -0
  23. package/dist/cjs/src/data-structures/graph/index.js.map +1 -0
  24. package/dist/cjs/src/data-structures/graph/map-graph.js.map +1 -0
  25. package/dist/cjs/src/data-structures/graph/undirected-graph.js.map +1 -0
  26. package/dist/cjs/src/data-structures/hash/coordinate-map.js.map +1 -0
  27. package/dist/cjs/src/data-structures/hash/coordinate-set.js.map +1 -0
  28. package/dist/cjs/src/data-structures/hash/hash-map.js.map +1 -0
  29. package/dist/cjs/src/data-structures/hash/hash-table.js.map +1 -0
  30. package/dist/cjs/src/data-structures/hash/index.js.map +1 -0
  31. package/dist/cjs/src/data-structures/hash/tree-map.js.map +1 -0
  32. package/dist/cjs/src/data-structures/hash/tree-set.js.map +1 -0
  33. package/dist/cjs/src/data-structures/heap/heap.js.map +1 -0
  34. package/dist/cjs/src/data-structures/heap/index.js.map +1 -0
  35. package/dist/cjs/src/data-structures/heap/max-heap.js.map +1 -0
  36. package/dist/cjs/src/data-structures/heap/min-heap.js.map +1 -0
  37. package/dist/cjs/src/data-structures/index.js.map +1 -0
  38. package/dist/cjs/src/data-structures/linked-list/doubly-linked-list.js.map +1 -0
  39. package/dist/cjs/src/data-structures/linked-list/index.js.map +1 -0
  40. package/dist/cjs/src/data-structures/linked-list/singly-linked-list.js.map +1 -0
  41. package/dist/cjs/src/data-structures/linked-list/skip-linked-list.js.map +1 -0
  42. package/dist/cjs/src/data-structures/matrix/index.js.map +1 -0
  43. package/dist/cjs/src/data-structures/matrix/matrix.js.map +1 -0
  44. package/dist/cjs/src/data-structures/matrix/matrix2d.js.map +1 -0
  45. package/dist/cjs/src/data-structures/matrix/navigator.js.map +1 -0
  46. package/dist/cjs/src/data-structures/matrix/vector2d.js.map +1 -0
  47. package/dist/cjs/src/data-structures/priority-queue/index.js.map +1 -0
  48. package/dist/cjs/src/data-structures/priority-queue/max-priority-queue.js.map +1 -0
  49. package/dist/cjs/src/data-structures/priority-queue/min-priority-queue.js.map +1 -0
  50. package/dist/cjs/src/data-structures/priority-queue/priority-queue.js.map +1 -0
  51. package/dist/cjs/src/data-structures/queue/deque.js.map +1 -0
  52. package/dist/cjs/src/data-structures/queue/index.js.map +1 -0
  53. package/dist/cjs/src/data-structures/queue/queue.js.map +1 -0
  54. package/dist/cjs/src/data-structures/stack/index.js.map +1 -0
  55. package/dist/cjs/src/data-structures/stack/stack.js.map +1 -0
  56. package/dist/cjs/src/data-structures/tree/index.js.map +1 -0
  57. package/dist/cjs/src/data-structures/tree/tree.js.map +1 -0
  58. package/dist/cjs/src/data-structures/trie/index.js.map +1 -0
  59. package/dist/cjs/src/data-structures/trie/trie.js.map +1 -0
  60. package/dist/cjs/src/index.js.map +1 -0
  61. package/dist/cjs/src/interfaces/binary-tree.js.map +1 -0
  62. package/dist/cjs/src/interfaces/doubly-linked-list.js.map +1 -0
  63. package/dist/cjs/{interfaces → src/interfaces}/graph.js.map +1 -1
  64. package/dist/cjs/{interfaces → src/interfaces}/heap.js.map +1 -1
  65. package/dist/cjs/src/interfaces/index.js.map +1 -0
  66. package/dist/cjs/src/interfaces/navigator.js.map +1 -0
  67. package/dist/cjs/src/interfaces/priority-queue.js.map +1 -0
  68. package/dist/cjs/src/interfaces/segment-tree.js.map +1 -0
  69. package/dist/cjs/src/interfaces/singly-linked-list.js.map +1 -0
  70. package/dist/cjs/src/types/data-structures/binary-tree/avl-tree.js.map +1 -0
  71. package/dist/cjs/src/types/data-structures/binary-tree/binary-indexed-tree.js.map +1 -0
  72. package/dist/cjs/src/types/data-structures/binary-tree/binary-tree.js.map +1 -0
  73. package/dist/cjs/src/types/data-structures/binary-tree/bst.js.map +1 -0
  74. package/dist/cjs/src/types/data-structures/binary-tree/index.js.map +1 -0
  75. package/dist/cjs/src/types/data-structures/binary-tree/rb-tree.js.map +1 -0
  76. package/dist/cjs/src/types/data-structures/binary-tree/segment-tree.js.map +1 -0
  77. package/dist/cjs/src/types/data-structures/binary-tree/tree-multiset.js.map +1 -0
  78. package/dist/cjs/src/types/data-structures/graph/abstract-graph.js.map +1 -0
  79. package/dist/cjs/src/types/data-structures/graph/directed-graph.js.map +1 -0
  80. package/dist/cjs/src/types/data-structures/graph/index.js.map +1 -0
  81. package/dist/cjs/src/types/data-structures/graph/map-graph.js.map +1 -0
  82. package/dist/cjs/src/types/data-structures/graph/undirected-graph.js.map +1 -0
  83. package/dist/cjs/src/types/data-structures/hash/coordinate-map.js.map +1 -0
  84. package/dist/cjs/src/types/data-structures/hash/coordinate-set.js.map +1 -0
  85. package/dist/cjs/src/types/data-structures/hash/hash-map.js.map +1 -0
  86. package/dist/cjs/src/types/data-structures/hash/hash-table.js.map +1 -0
  87. package/dist/cjs/src/types/data-structures/hash/index.js.map +1 -0
  88. package/dist/cjs/src/types/data-structures/hash/tree-map.js.map +1 -0
  89. package/dist/cjs/src/types/data-structures/hash/tree-set.js.map +1 -0
  90. package/dist/cjs/src/types/data-structures/heap/heap.js.map +1 -0
  91. package/dist/cjs/src/types/data-structures/heap/index.js.map +1 -0
  92. package/dist/cjs/src/types/data-structures/heap/max-heap.js.map +1 -0
  93. package/dist/cjs/src/types/data-structures/heap/min-heap.js.map +1 -0
  94. package/dist/cjs/src/types/data-structures/index.js.map +1 -0
  95. package/dist/cjs/src/types/data-structures/linked-list/doubly-linked-list.js.map +1 -0
  96. package/dist/cjs/src/types/data-structures/linked-list/index.js.map +1 -0
  97. package/dist/cjs/src/types/data-structures/linked-list/singly-linked-list.js.map +1 -0
  98. package/dist/cjs/src/types/data-structures/linked-list/skip-linked-list.js.map +1 -0
  99. package/dist/cjs/src/types/data-structures/matrix/index.js.map +1 -0
  100. package/dist/cjs/src/types/data-structures/matrix/matrix.js.map +1 -0
  101. package/dist/cjs/src/types/data-structures/matrix/matrix2d.js.map +1 -0
  102. package/dist/cjs/src/types/data-structures/matrix/navigator.js.map +1 -0
  103. package/dist/cjs/src/types/data-structures/matrix/vector2d.js.map +1 -0
  104. package/dist/cjs/src/types/data-structures/priority-queue/index.js.map +1 -0
  105. package/dist/cjs/src/types/data-structures/priority-queue/max-priority-queue.js.map +1 -0
  106. package/dist/cjs/src/types/data-structures/priority-queue/min-priority-queue.js.map +1 -0
  107. package/dist/cjs/src/types/data-structures/priority-queue/priority-queue.js.map +1 -0
  108. package/dist/cjs/src/types/data-structures/queue/deque.js.map +1 -0
  109. package/dist/cjs/src/types/data-structures/queue/index.js.map +1 -0
  110. package/dist/cjs/src/types/data-structures/queue/queue.js.map +1 -0
  111. package/dist/cjs/src/types/data-structures/stack/index.js.map +1 -0
  112. package/dist/cjs/src/types/data-structures/stack/stack.js.map +1 -0
  113. package/dist/cjs/src/types/data-structures/tree/index.js.map +1 -0
  114. package/dist/cjs/src/types/data-structures/tree/tree.js.map +1 -0
  115. package/dist/cjs/src/types/data-structures/trie/index.js.map +1 -0
  116. package/dist/cjs/src/types/data-structures/trie/trie.js.map +1 -0
  117. package/dist/cjs/src/types/helpers.js.map +1 -0
  118. package/dist/cjs/src/types/index.js.map +1 -0
  119. package/dist/cjs/src/types/utils/index.js.map +1 -0
  120. package/dist/cjs/{types → src/types}/utils/utils.js.map +1 -1
  121. package/dist/cjs/src/types/utils/validate-type.js.map +1 -0
  122. package/dist/cjs/src/utils/index.js.map +1 -0
  123. package/dist/cjs/src/utils/utils.js.map +1 -0
  124. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/avl-tree.d.ts +1 -1
  125. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/avl-tree.js +2 -2
  126. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/binary-tree.d.ts +4 -3
  127. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/binary-tree.js +19 -18
  128. package/dist/{cjs → mjs/src}/data-structures/binary-tree/bst.d.ts +1 -20
  129. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/bst.js +5 -26
  130. package/dist/{cjs → mjs/src}/data-structures/binary-tree/tree-multiset.d.ts +1 -1
  131. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/tree-multiset.js +2 -2
  132. package/dist/umd/data-structure-typed.min.js +1 -1
  133. package/dist/umd/data-structure-typed.min.js.map +1 -1
  134. package/package.json +8 -8
  135. package/src/data-structures/binary-tree/avl-tree.ts +2 -2
  136. package/src/data-structures/binary-tree/binary-tree.ts +20 -18
  137. package/src/data-structures/binary-tree/bst.ts +6 -33
  138. package/src/data-structures/binary-tree/tree-multiset.ts +2 -2
  139. package/tsconfig-base.json +20 -24
  140. package/tsconfig-cjs.json +5 -1
  141. package/tsconfig-mjs.json +12 -0
  142. package/dist/cjs/data-structures/binary-tree/avl-tree.js.map +0 -1
  143. package/dist/cjs/data-structures/binary-tree/binary-indexed-tree.js.map +0 -1
  144. package/dist/cjs/data-structures/binary-tree/binary-tree.js.map +0 -1
  145. package/dist/cjs/data-structures/binary-tree/bst.js.map +0 -1
  146. package/dist/cjs/data-structures/binary-tree/index.js.map +0 -1
  147. package/dist/cjs/data-structures/binary-tree/rb-tree.js.map +0 -1
  148. package/dist/cjs/data-structures/binary-tree/segment-tree.js.map +0 -1
  149. package/dist/cjs/data-structures/binary-tree/tree-multiset.js.map +0 -1
  150. package/dist/cjs/data-structures/graph/abstract-graph.js.map +0 -1
  151. package/dist/cjs/data-structures/graph/directed-graph.js.map +0 -1
  152. package/dist/cjs/data-structures/graph/index.js.map +0 -1
  153. package/dist/cjs/data-structures/graph/map-graph.js.map +0 -1
  154. package/dist/cjs/data-structures/graph/undirected-graph.js.map +0 -1
  155. package/dist/cjs/data-structures/hash/coordinate-map.js.map +0 -1
  156. package/dist/cjs/data-structures/hash/coordinate-set.js.map +0 -1
  157. package/dist/cjs/data-structures/hash/hash-map.js.map +0 -1
  158. package/dist/cjs/data-structures/hash/hash-table.js.map +0 -1
  159. package/dist/cjs/data-structures/hash/index.js.map +0 -1
  160. package/dist/cjs/data-structures/hash/tree-map.js.map +0 -1
  161. package/dist/cjs/data-structures/hash/tree-set.js.map +0 -1
  162. package/dist/cjs/data-structures/heap/heap.js.map +0 -1
  163. package/dist/cjs/data-structures/heap/index.js.map +0 -1
  164. package/dist/cjs/data-structures/heap/max-heap.js.map +0 -1
  165. package/dist/cjs/data-structures/heap/min-heap.js.map +0 -1
  166. package/dist/cjs/data-structures/index.js.map +0 -1
  167. package/dist/cjs/data-structures/linked-list/doubly-linked-list.js.map +0 -1
  168. package/dist/cjs/data-structures/linked-list/index.js.map +0 -1
  169. package/dist/cjs/data-structures/linked-list/singly-linked-list.js.map +0 -1
  170. package/dist/cjs/data-structures/linked-list/skip-linked-list.js.map +0 -1
  171. package/dist/cjs/data-structures/matrix/index.js.map +0 -1
  172. package/dist/cjs/data-structures/matrix/matrix.js.map +0 -1
  173. package/dist/cjs/data-structures/matrix/matrix2d.js.map +0 -1
  174. package/dist/cjs/data-structures/matrix/navigator.js.map +0 -1
  175. package/dist/cjs/data-structures/matrix/vector2d.js.map +0 -1
  176. package/dist/cjs/data-structures/priority-queue/index.js.map +0 -1
  177. package/dist/cjs/data-structures/priority-queue/max-priority-queue.js.map +0 -1
  178. package/dist/cjs/data-structures/priority-queue/min-priority-queue.js.map +0 -1
  179. package/dist/cjs/data-structures/priority-queue/priority-queue.js.map +0 -1
  180. package/dist/cjs/data-structures/queue/deque.js.map +0 -1
  181. package/dist/cjs/data-structures/queue/index.js.map +0 -1
  182. package/dist/cjs/data-structures/queue/queue.js.map +0 -1
  183. package/dist/cjs/data-structures/stack/index.js.map +0 -1
  184. package/dist/cjs/data-structures/stack/stack.js.map +0 -1
  185. package/dist/cjs/data-structures/tree/index.js.map +0 -1
  186. package/dist/cjs/data-structures/tree/tree.js.map +0 -1
  187. package/dist/cjs/data-structures/trie/index.js.map +0 -1
  188. package/dist/cjs/data-structures/trie/trie.js.map +0 -1
  189. package/dist/cjs/index.js.map +0 -1
  190. package/dist/cjs/interfaces/binary-tree.js.map +0 -1
  191. package/dist/cjs/interfaces/doubly-linked-list.js.map +0 -1
  192. package/dist/cjs/interfaces/index.js.map +0 -1
  193. package/dist/cjs/interfaces/navigator.js.map +0 -1
  194. package/dist/cjs/interfaces/priority-queue.js.map +0 -1
  195. package/dist/cjs/interfaces/segment-tree.js.map +0 -1
  196. package/dist/cjs/interfaces/singly-linked-list.js.map +0 -1
  197. package/dist/cjs/types/data-structures/binary-tree/avl-tree.js.map +0 -1
  198. package/dist/cjs/types/data-structures/binary-tree/binary-indexed-tree.js.map +0 -1
  199. package/dist/cjs/types/data-structures/binary-tree/binary-tree.js.map +0 -1
  200. package/dist/cjs/types/data-structures/binary-tree/bst.js.map +0 -1
  201. package/dist/cjs/types/data-structures/binary-tree/index.js.map +0 -1
  202. package/dist/cjs/types/data-structures/binary-tree/rb-tree.js.map +0 -1
  203. package/dist/cjs/types/data-structures/binary-tree/segment-tree.js.map +0 -1
  204. package/dist/cjs/types/data-structures/binary-tree/tree-multiset.js.map +0 -1
  205. package/dist/cjs/types/data-structures/graph/abstract-graph.js.map +0 -1
  206. package/dist/cjs/types/data-structures/graph/directed-graph.js.map +0 -1
  207. package/dist/cjs/types/data-structures/graph/index.js.map +0 -1
  208. package/dist/cjs/types/data-structures/graph/map-graph.js.map +0 -1
  209. package/dist/cjs/types/data-structures/graph/undirected-graph.js.map +0 -1
  210. package/dist/cjs/types/data-structures/hash/coordinate-map.js.map +0 -1
  211. package/dist/cjs/types/data-structures/hash/coordinate-set.js.map +0 -1
  212. package/dist/cjs/types/data-structures/hash/hash-map.js.map +0 -1
  213. package/dist/cjs/types/data-structures/hash/hash-table.js.map +0 -1
  214. package/dist/cjs/types/data-structures/hash/index.js.map +0 -1
  215. package/dist/cjs/types/data-structures/hash/tree-map.js.map +0 -1
  216. package/dist/cjs/types/data-structures/hash/tree-set.js.map +0 -1
  217. package/dist/cjs/types/data-structures/heap/heap.js.map +0 -1
  218. package/dist/cjs/types/data-structures/heap/index.js.map +0 -1
  219. package/dist/cjs/types/data-structures/heap/max-heap.js.map +0 -1
  220. package/dist/cjs/types/data-structures/heap/min-heap.js.map +0 -1
  221. package/dist/cjs/types/data-structures/index.js.map +0 -1
  222. package/dist/cjs/types/data-structures/linked-list/doubly-linked-list.js.map +0 -1
  223. package/dist/cjs/types/data-structures/linked-list/index.js.map +0 -1
  224. package/dist/cjs/types/data-structures/linked-list/singly-linked-list.js.map +0 -1
  225. package/dist/cjs/types/data-structures/linked-list/skip-linked-list.js.map +0 -1
  226. package/dist/cjs/types/data-structures/matrix/index.js.map +0 -1
  227. package/dist/cjs/types/data-structures/matrix/matrix.js.map +0 -1
  228. package/dist/cjs/types/data-structures/matrix/matrix2d.js.map +0 -1
  229. package/dist/cjs/types/data-structures/matrix/navigator.js.map +0 -1
  230. package/dist/cjs/types/data-structures/matrix/vector2d.js.map +0 -1
  231. package/dist/cjs/types/data-structures/priority-queue/index.js.map +0 -1
  232. package/dist/cjs/types/data-structures/priority-queue/max-priority-queue.js.map +0 -1
  233. package/dist/cjs/types/data-structures/priority-queue/min-priority-queue.js.map +0 -1
  234. package/dist/cjs/types/data-structures/priority-queue/priority-queue.js.map +0 -1
  235. package/dist/cjs/types/data-structures/queue/deque.js.map +0 -1
  236. package/dist/cjs/types/data-structures/queue/index.js.map +0 -1
  237. package/dist/cjs/types/data-structures/queue/queue.js.map +0 -1
  238. package/dist/cjs/types/data-structures/stack/index.js.map +0 -1
  239. package/dist/cjs/types/data-structures/stack/stack.js.map +0 -1
  240. package/dist/cjs/types/data-structures/tree/index.js.map +0 -1
  241. package/dist/cjs/types/data-structures/tree/tree.js.map +0 -1
  242. package/dist/cjs/types/data-structures/trie/index.js.map +0 -1
  243. package/dist/cjs/types/data-structures/trie/trie.js.map +0 -1
  244. package/dist/cjs/types/helpers.js.map +0 -1
  245. package/dist/cjs/types/index.js.map +0 -1
  246. package/dist/cjs/types/utils/index.js.map +0 -1
  247. package/dist/cjs/types/utils/validate-type.js.map +0 -1
  248. package/dist/cjs/utils/index.js.map +0 -1
  249. package/dist/cjs/utils/utils.js.map +0 -1
  250. package/test/config.ts +0 -1
  251. package/test/integration/avl-tree.test.ts +0 -110
  252. package/test/integration/bst.test.ts +0 -385
  253. package/test/integration/heap.test.js +0 -16
  254. package/test/integration/index.html +0 -51
  255. package/test/performance/data-structures/binary-tree/avl-tree.test.ts +0 -36
  256. package/test/performance/data-structures/binary-tree/binary-index-tree.test.ts +0 -0
  257. package/test/performance/data-structures/binary-tree/binary-tree.test.ts +0 -45
  258. package/test/performance/data-structures/binary-tree/bst.test.ts +0 -36
  259. package/test/performance/data-structures/binary-tree/overall.test.ts +0 -0
  260. package/test/performance/data-structures/binary-tree/rb-tree.test.ts +0 -0
  261. package/test/performance/data-structures/binary-tree/segment-tree.test.ts +0 -0
  262. package/test/performance/data-structures/binary-tree/tree-multiset.test.ts +0 -0
  263. package/test/performance/data-structures/graph/abstract-graph.test.ts +0 -0
  264. package/test/performance/data-structures/graph/directed-graph.test.ts +0 -49
  265. package/test/performance/data-structures/graph/map-graph.test.ts +0 -0
  266. package/test/performance/data-structures/graph/overall.test.ts +0 -0
  267. package/test/performance/data-structures/graph/undirected-graph.test.ts +0 -0
  268. package/test/performance/data-structures/hash/coordinate-map.test.ts +0 -0
  269. package/test/performance/data-structures/hash/coordinate-set.test.ts +0 -0
  270. package/test/performance/data-structures/hash/hash-map.test.ts +0 -0
  271. package/test/performance/data-structures/hash/hash-table.test.ts +0 -0
  272. package/test/performance/data-structures/heap/heap.test.ts +0 -30
  273. package/test/performance/data-structures/heap/max-heap.test.ts +0 -0
  274. package/test/performance/data-structures/heap/min-heap.test.ts +0 -0
  275. package/test/performance/data-structures/linked-list/doubly-linked-list.test.ts +0 -40
  276. package/test/performance/data-structures/linked-list/linked-list.test.ts +0 -0
  277. package/test/performance/data-structures/linked-list/singly-linked-list.test.ts +0 -34
  278. package/test/performance/data-structures/linked-list/skip-linked-list.test.ts +0 -0
  279. package/test/performance/data-structures/linked-list/skip-list.test.ts +0 -0
  280. package/test/performance/data-structures/matrix/matrix.test.ts +0 -0
  281. package/test/performance/data-structures/matrix/matrix2d.test.ts +0 -0
  282. package/test/performance/data-structures/matrix/navigator.test.ts +0 -0
  283. package/test/performance/data-structures/matrix/vector2d.test.ts +0 -0
  284. package/test/performance/data-structures/priority-queue/max-priority-queue.test.ts +0 -19
  285. package/test/performance/data-structures/priority-queue/min-priority-queue.test.ts +0 -0
  286. package/test/performance/data-structures/priority-queue/priority-queue.test.ts +0 -0
  287. package/test/performance/data-structures/queue/deque.test.ts +0 -21
  288. package/test/performance/data-structures/queue/queue.test.ts +0 -25
  289. package/test/performance/data-structures/stack/stack.test.ts +0 -0
  290. package/test/performance/data-structures/tree/tree.test.ts +0 -0
  291. package/test/performance/data-structures/trie/trie.test.ts +0 -22
  292. package/test/performance/reportor.ts +0 -183
  293. package/test/performance/types/index.ts +0 -1
  294. package/test/performance/types/reportor.ts +0 -3
  295. package/test/types/index.ts +0 -1
  296. package/test/types/utils/big-o.ts +0 -1
  297. package/test/types/utils/index.ts +0 -2
  298. package/test/types/utils/json2html.ts +0 -1
  299. package/test/unit/data-structures/binary-tree/avl-tree.test.ts +0 -269
  300. package/test/unit/data-structures/binary-tree/binary-index-tree.test.ts +0 -320
  301. package/test/unit/data-structures/binary-tree/binary-tree.test.ts +0 -486
  302. package/test/unit/data-structures/binary-tree/bst.test.ts +0 -840
  303. package/test/unit/data-structures/binary-tree/overall.test.ts +0 -66
  304. package/test/unit/data-structures/binary-tree/rb-tree.test.ts +0 -435
  305. package/test/unit/data-structures/binary-tree/segment-tree.test.ts +0 -50
  306. package/test/unit/data-structures/binary-tree/tree-multiset.test.ts +0 -542
  307. package/test/unit/data-structures/graph/abstract-graph.test.ts +0 -100
  308. package/test/unit/data-structures/graph/directed-graph.test.ts +0 -564
  309. package/test/unit/data-structures/graph/map-graph.test.ts +0 -126
  310. package/test/unit/data-structures/graph/overall.test.ts +0 -49
  311. package/test/unit/data-structures/graph/undirected-graph.test.ts +0 -149
  312. package/test/unit/data-structures/hash/coordinate-map.test.ts +0 -74
  313. package/test/unit/data-structures/hash/coordinate-set.test.ts +0 -66
  314. package/test/unit/data-structures/hash/hash-map.test.ts +0 -103
  315. package/test/unit/data-structures/hash/hash-table.test.ts +0 -186
  316. package/test/unit/data-structures/heap/heap.test.ts +0 -254
  317. package/test/unit/data-structures/heap/max-heap.test.ts +0 -52
  318. package/test/unit/data-structures/heap/min-heap.test.ts +0 -52
  319. package/test/unit/data-structures/linked-list/doubly-linked-list.test.ts +0 -400
  320. package/test/unit/data-structures/linked-list/linked-list.test.ts +0 -8
  321. package/test/unit/data-structures/linked-list/singly-linked-list.test.ts +0 -474
  322. package/test/unit/data-structures/linked-list/skip-linked-list.test.ts +0 -13
  323. package/test/unit/data-structures/linked-list/skip-list.test.ts +0 -86
  324. package/test/unit/data-structures/matrix/matrix.test.ts +0 -54
  325. package/test/unit/data-structures/matrix/matrix2d.test.ts +0 -345
  326. package/test/unit/data-structures/matrix/navigator.test.ts +0 -244
  327. package/test/unit/data-structures/matrix/vector2d.test.ts +0 -171
  328. package/test/unit/data-structures/priority-queue/max-priority-queue.test.ts +0 -73
  329. package/test/unit/data-structures/priority-queue/min-priority-queue.test.ts +0 -63
  330. package/test/unit/data-structures/priority-queue/priority-queue.test.ts +0 -53
  331. package/test/unit/data-structures/queue/deque.test.ts +0 -410
  332. package/test/unit/data-structures/queue/queue.test.ts +0 -207
  333. package/test/unit/data-structures/stack/stack.test.ts +0 -67
  334. package/test/unit/data-structures/tree/tree.test.ts +0 -39
  335. package/test/unit/data-structures/trie/trie.test.ts +0 -825
  336. package/test/utils/array.ts +0 -5514
  337. package/test/utils/big-o.ts +0 -207
  338. package/test/utils/console.ts +0 -31
  339. package/test/utils/index.ts +0 -7
  340. package/test/utils/is.ts +0 -56
  341. package/test/utils/json2html.ts +0 -322
  342. package/test/utils/number.ts +0 -13
  343. package/test/utils/string.ts +0 -1
  344. package/umd/bundle.min.js +0 -3
  345. package/umd/bundle.min.js.LICENSE.txt +0 -28
  346. package/umd/bundle.min.js.map +0 -1
  347. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/binary-indexed-tree.d.ts +0 -0
  348. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/binary-indexed-tree.js +0 -0
  349. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/index.d.ts +0 -0
  350. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/index.js +0 -0
  351. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/rb-tree.d.ts +0 -0
  352. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/rb-tree.js +0 -0
  353. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/segment-tree.d.ts +0 -0
  354. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/segment-tree.js +0 -0
  355. /package/dist/cjs/{data-structures → src/data-structures}/graph/abstract-graph.d.ts +0 -0
  356. /package/dist/cjs/{data-structures → src/data-structures}/graph/abstract-graph.js +0 -0
  357. /package/dist/cjs/{data-structures → src/data-structures}/graph/directed-graph.d.ts +0 -0
  358. /package/dist/cjs/{data-structures → src/data-structures}/graph/directed-graph.js +0 -0
  359. /package/dist/cjs/{data-structures → src/data-structures}/graph/index.d.ts +0 -0
  360. /package/dist/cjs/{data-structures → src/data-structures}/graph/index.js +0 -0
  361. /package/dist/cjs/{data-structures → src/data-structures}/graph/map-graph.d.ts +0 -0
  362. /package/dist/cjs/{data-structures → src/data-structures}/graph/map-graph.js +0 -0
  363. /package/dist/cjs/{data-structures → src/data-structures}/graph/undirected-graph.d.ts +0 -0
  364. /package/dist/cjs/{data-structures → src/data-structures}/graph/undirected-graph.js +0 -0
  365. /package/dist/cjs/{data-structures → src/data-structures}/hash/coordinate-map.d.ts +0 -0
  366. /package/dist/cjs/{data-structures → src/data-structures}/hash/coordinate-map.js +0 -0
  367. /package/dist/cjs/{data-structures → src/data-structures}/hash/coordinate-set.d.ts +0 -0
  368. /package/dist/cjs/{data-structures → src/data-structures}/hash/coordinate-set.js +0 -0
  369. /package/dist/cjs/{data-structures → src/data-structures}/hash/hash-map.d.ts +0 -0
  370. /package/dist/cjs/{data-structures → src/data-structures}/hash/hash-map.js +0 -0
  371. /package/dist/cjs/{data-structures → src/data-structures}/hash/hash-table.d.ts +0 -0
  372. /package/dist/cjs/{data-structures → src/data-structures}/hash/hash-table.js +0 -0
  373. /package/dist/cjs/{data-structures → src/data-structures}/hash/index.d.ts +0 -0
  374. /package/dist/cjs/{data-structures → src/data-structures}/hash/index.js +0 -0
  375. /package/dist/cjs/{data-structures → src/data-structures}/hash/tree-map.d.ts +0 -0
  376. /package/dist/cjs/{data-structures → src/data-structures}/hash/tree-map.js +0 -0
  377. /package/dist/cjs/{data-structures → src/data-structures}/hash/tree-set.d.ts +0 -0
  378. /package/dist/cjs/{data-structures → src/data-structures}/hash/tree-set.js +0 -0
  379. /package/dist/cjs/{data-structures → src/data-structures}/heap/heap.d.ts +0 -0
  380. /package/dist/cjs/{data-structures → src/data-structures}/heap/heap.js +0 -0
  381. /package/dist/cjs/{data-structures → src/data-structures}/heap/index.d.ts +0 -0
  382. /package/dist/cjs/{data-structures → src/data-structures}/heap/index.js +0 -0
  383. /package/dist/cjs/{data-structures → src/data-structures}/heap/max-heap.d.ts +0 -0
  384. /package/dist/cjs/{data-structures → src/data-structures}/heap/max-heap.js +0 -0
  385. /package/dist/cjs/{data-structures → src/data-structures}/heap/min-heap.d.ts +0 -0
  386. /package/dist/cjs/{data-structures → src/data-structures}/heap/min-heap.js +0 -0
  387. /package/dist/cjs/{data-structures → src/data-structures}/index.d.ts +0 -0
  388. /package/dist/cjs/{data-structures → src/data-structures}/index.js +0 -0
  389. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/doubly-linked-list.d.ts +0 -0
  390. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/doubly-linked-list.js +0 -0
  391. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/index.d.ts +0 -0
  392. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/index.js +0 -0
  393. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/singly-linked-list.d.ts +0 -0
  394. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/singly-linked-list.js +0 -0
  395. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/skip-linked-list.d.ts +0 -0
  396. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/skip-linked-list.js +0 -0
  397. /package/dist/cjs/{data-structures → src/data-structures}/matrix/index.d.ts +0 -0
  398. /package/dist/cjs/{data-structures → src/data-structures}/matrix/index.js +0 -0
  399. /package/dist/cjs/{data-structures → src/data-structures}/matrix/matrix.d.ts +0 -0
  400. /package/dist/cjs/{data-structures → src/data-structures}/matrix/matrix.js +0 -0
  401. /package/dist/cjs/{data-structures → src/data-structures}/matrix/matrix2d.d.ts +0 -0
  402. /package/dist/cjs/{data-structures → src/data-structures}/matrix/matrix2d.js +0 -0
  403. /package/dist/cjs/{data-structures → src/data-structures}/matrix/navigator.d.ts +0 -0
  404. /package/dist/cjs/{data-structures → src/data-structures}/matrix/navigator.js +0 -0
  405. /package/dist/cjs/{data-structures → src/data-structures}/matrix/vector2d.d.ts +0 -0
  406. /package/dist/cjs/{data-structures → src/data-structures}/matrix/vector2d.js +0 -0
  407. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/index.d.ts +0 -0
  408. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/index.js +0 -0
  409. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/max-priority-queue.d.ts +0 -0
  410. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/max-priority-queue.js +0 -0
  411. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/min-priority-queue.d.ts +0 -0
  412. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/min-priority-queue.js +0 -0
  413. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/priority-queue.d.ts +0 -0
  414. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/priority-queue.js +0 -0
  415. /package/dist/cjs/{data-structures → src/data-structures}/queue/deque.d.ts +0 -0
  416. /package/dist/cjs/{data-structures → src/data-structures}/queue/deque.js +0 -0
  417. /package/dist/cjs/{data-structures → src/data-structures}/queue/index.d.ts +0 -0
  418. /package/dist/cjs/{data-structures → src/data-structures}/queue/index.js +0 -0
  419. /package/dist/cjs/{data-structures → src/data-structures}/queue/queue.d.ts +0 -0
  420. /package/dist/cjs/{data-structures → src/data-structures}/queue/queue.js +0 -0
  421. /package/dist/cjs/{data-structures → src/data-structures}/stack/index.d.ts +0 -0
  422. /package/dist/cjs/{data-structures → src/data-structures}/stack/index.js +0 -0
  423. /package/dist/cjs/{data-structures → src/data-structures}/stack/stack.d.ts +0 -0
  424. /package/dist/cjs/{data-structures → src/data-structures}/stack/stack.js +0 -0
  425. /package/dist/cjs/{data-structures → src/data-structures}/tree/index.d.ts +0 -0
  426. /package/dist/cjs/{data-structures → src/data-structures}/tree/index.js +0 -0
  427. /package/dist/cjs/{data-structures → src/data-structures}/tree/tree.d.ts +0 -0
  428. /package/dist/cjs/{data-structures → src/data-structures}/tree/tree.js +0 -0
  429. /package/dist/cjs/{data-structures → src/data-structures}/trie/index.d.ts +0 -0
  430. /package/dist/cjs/{data-structures → src/data-structures}/trie/index.js +0 -0
  431. /package/dist/cjs/{data-structures → src/data-structures}/trie/trie.d.ts +0 -0
  432. /package/dist/cjs/{data-structures → src/data-structures}/trie/trie.js +0 -0
  433. /package/dist/cjs/{index.d.ts → src/index.d.ts} +0 -0
  434. /package/dist/cjs/{index.js → src/index.js} +0 -0
  435. /package/dist/cjs/{interfaces → src/interfaces}/binary-tree.d.ts +0 -0
  436. /package/dist/cjs/{interfaces → src/interfaces}/binary-tree.js +0 -0
  437. /package/dist/cjs/{interfaces → src/interfaces}/doubly-linked-list.d.ts +0 -0
  438. /package/dist/cjs/{interfaces → src/interfaces}/doubly-linked-list.js +0 -0
  439. /package/dist/cjs/{interfaces → src/interfaces}/graph.d.ts +0 -0
  440. /package/dist/cjs/{interfaces → src/interfaces}/graph.js +0 -0
  441. /package/dist/cjs/{interfaces → src/interfaces}/heap.d.ts +0 -0
  442. /package/dist/cjs/{interfaces → src/interfaces}/heap.js +0 -0
  443. /package/dist/cjs/{interfaces → src/interfaces}/index.d.ts +0 -0
  444. /package/dist/cjs/{interfaces → src/interfaces}/index.js +0 -0
  445. /package/dist/cjs/{interfaces → src/interfaces}/navigator.d.ts +0 -0
  446. /package/dist/cjs/{interfaces → src/interfaces}/navigator.js +0 -0
  447. /package/dist/cjs/{interfaces → src/interfaces}/priority-queue.d.ts +0 -0
  448. /package/dist/cjs/{interfaces → src/interfaces}/priority-queue.js +0 -0
  449. /package/dist/cjs/{interfaces → src/interfaces}/segment-tree.d.ts +0 -0
  450. /package/dist/cjs/{interfaces → src/interfaces}/segment-tree.js +0 -0
  451. /package/dist/cjs/{interfaces → src/interfaces}/singly-linked-list.d.ts +0 -0
  452. /package/dist/cjs/{interfaces → src/interfaces}/singly-linked-list.js +0 -0
  453. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/avl-tree.d.ts +0 -0
  454. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/avl-tree.js +0 -0
  455. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/binary-indexed-tree.d.ts +0 -0
  456. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/binary-indexed-tree.js +0 -0
  457. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/binary-tree.d.ts +0 -0
  458. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/binary-tree.js +0 -0
  459. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/bst.d.ts +0 -0
  460. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/bst.js +0 -0
  461. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/index.d.ts +0 -0
  462. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/index.js +0 -0
  463. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/rb-tree.d.ts +0 -0
  464. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/rb-tree.js +0 -0
  465. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/segment-tree.d.ts +0 -0
  466. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/segment-tree.js +0 -0
  467. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/tree-multiset.d.ts +0 -0
  468. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/tree-multiset.js +0 -0
  469. /package/dist/cjs/{types → src/types}/data-structures/graph/abstract-graph.d.ts +0 -0
  470. /package/dist/cjs/{types → src/types}/data-structures/graph/abstract-graph.js +0 -0
  471. /package/dist/cjs/{types → src/types}/data-structures/graph/directed-graph.d.ts +0 -0
  472. /package/dist/cjs/{types → src/types}/data-structures/graph/directed-graph.js +0 -0
  473. /package/dist/cjs/{types → src/types}/data-structures/graph/index.d.ts +0 -0
  474. /package/dist/cjs/{types → src/types}/data-structures/graph/index.js +0 -0
  475. /package/dist/cjs/{types → src/types}/data-structures/graph/map-graph.d.ts +0 -0
  476. /package/dist/cjs/{types → src/types}/data-structures/graph/map-graph.js +0 -0
  477. /package/dist/cjs/{types → src/types}/data-structures/graph/undirected-graph.d.ts +0 -0
  478. /package/dist/cjs/{types → src/types}/data-structures/graph/undirected-graph.js +0 -0
  479. /package/dist/cjs/{types → src/types}/data-structures/hash/coordinate-map.d.ts +0 -0
  480. /package/dist/cjs/{types → src/types}/data-structures/hash/coordinate-map.js +0 -0
  481. /package/dist/cjs/{types → src/types}/data-structures/hash/coordinate-set.d.ts +0 -0
  482. /package/dist/cjs/{types → src/types}/data-structures/hash/coordinate-set.js +0 -0
  483. /package/dist/cjs/{types → src/types}/data-structures/hash/hash-map.d.ts +0 -0
  484. /package/dist/cjs/{types → src/types}/data-structures/hash/hash-map.js +0 -0
  485. /package/dist/cjs/{types → src/types}/data-structures/hash/hash-table.d.ts +0 -0
  486. /package/dist/cjs/{types → src/types}/data-structures/hash/hash-table.js +0 -0
  487. /package/dist/cjs/{types → src/types}/data-structures/hash/index.d.ts +0 -0
  488. /package/dist/cjs/{types → src/types}/data-structures/hash/index.js +0 -0
  489. /package/dist/cjs/{types → src/types}/data-structures/hash/tree-map.d.ts +0 -0
  490. /package/dist/cjs/{types → src/types}/data-structures/hash/tree-map.js +0 -0
  491. /package/dist/cjs/{types → src/types}/data-structures/hash/tree-set.d.ts +0 -0
  492. /package/dist/cjs/{types → src/types}/data-structures/hash/tree-set.js +0 -0
  493. /package/dist/cjs/{types → src/types}/data-structures/heap/heap.d.ts +0 -0
  494. /package/dist/cjs/{types → src/types}/data-structures/heap/heap.js +0 -0
  495. /package/dist/cjs/{types → src/types}/data-structures/heap/index.d.ts +0 -0
  496. /package/dist/cjs/{types → src/types}/data-structures/heap/index.js +0 -0
  497. /package/dist/cjs/{types → src/types}/data-structures/heap/max-heap.d.ts +0 -0
  498. /package/dist/cjs/{types → src/types}/data-structures/heap/max-heap.js +0 -0
  499. /package/dist/cjs/{types → src/types}/data-structures/heap/min-heap.d.ts +0 -0
  500. /package/dist/cjs/{types → src/types}/data-structures/heap/min-heap.js +0 -0
  501. /package/dist/cjs/{types → src/types}/data-structures/index.d.ts +0 -0
  502. /package/dist/cjs/{types → src/types}/data-structures/index.js +0 -0
  503. /package/dist/cjs/{types → src/types}/data-structures/linked-list/doubly-linked-list.d.ts +0 -0
  504. /package/dist/cjs/{types → src/types}/data-structures/linked-list/doubly-linked-list.js +0 -0
  505. /package/dist/cjs/{types → src/types}/data-structures/linked-list/index.d.ts +0 -0
  506. /package/dist/cjs/{types → src/types}/data-structures/linked-list/index.js +0 -0
  507. /package/dist/cjs/{types → src/types}/data-structures/linked-list/singly-linked-list.d.ts +0 -0
  508. /package/dist/cjs/{types → src/types}/data-structures/linked-list/singly-linked-list.js +0 -0
  509. /package/dist/cjs/{types → src/types}/data-structures/linked-list/skip-linked-list.d.ts +0 -0
  510. /package/dist/cjs/{types → src/types}/data-structures/linked-list/skip-linked-list.js +0 -0
  511. /package/dist/cjs/{types → src/types}/data-structures/matrix/index.d.ts +0 -0
  512. /package/dist/cjs/{types → src/types}/data-structures/matrix/index.js +0 -0
  513. /package/dist/cjs/{types → src/types}/data-structures/matrix/matrix.d.ts +0 -0
  514. /package/dist/cjs/{types → src/types}/data-structures/matrix/matrix.js +0 -0
  515. /package/dist/cjs/{types → src/types}/data-structures/matrix/matrix2d.d.ts +0 -0
  516. /package/dist/cjs/{types → src/types}/data-structures/matrix/matrix2d.js +0 -0
  517. /package/dist/cjs/{types → src/types}/data-structures/matrix/navigator.d.ts +0 -0
  518. /package/dist/cjs/{types → src/types}/data-structures/matrix/navigator.js +0 -0
  519. /package/dist/cjs/{types → src/types}/data-structures/matrix/vector2d.d.ts +0 -0
  520. /package/dist/cjs/{types → src/types}/data-structures/matrix/vector2d.js +0 -0
  521. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/index.d.ts +0 -0
  522. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/index.js +0 -0
  523. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/max-priority-queue.d.ts +0 -0
  524. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/max-priority-queue.js +0 -0
  525. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/min-priority-queue.d.ts +0 -0
  526. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/min-priority-queue.js +0 -0
  527. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/priority-queue.d.ts +0 -0
  528. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/priority-queue.js +0 -0
  529. /package/dist/cjs/{types → src/types}/data-structures/queue/deque.d.ts +0 -0
  530. /package/dist/cjs/{types → src/types}/data-structures/queue/deque.js +0 -0
  531. /package/dist/cjs/{types → src/types}/data-structures/queue/index.d.ts +0 -0
  532. /package/dist/cjs/{types → src/types}/data-structures/queue/index.js +0 -0
  533. /package/dist/cjs/{types → src/types}/data-structures/queue/queue.d.ts +0 -0
  534. /package/dist/cjs/{types → src/types}/data-structures/queue/queue.js +0 -0
  535. /package/dist/cjs/{types → src/types}/data-structures/stack/index.d.ts +0 -0
  536. /package/dist/cjs/{types → src/types}/data-structures/stack/index.js +0 -0
  537. /package/dist/cjs/{types → src/types}/data-structures/stack/stack.d.ts +0 -0
  538. /package/dist/cjs/{types → src/types}/data-structures/stack/stack.js +0 -0
  539. /package/dist/cjs/{types → src/types}/data-structures/tree/index.d.ts +0 -0
  540. /package/dist/cjs/{types → src/types}/data-structures/tree/index.js +0 -0
  541. /package/dist/cjs/{types → src/types}/data-structures/tree/tree.d.ts +0 -0
  542. /package/dist/cjs/{types → src/types}/data-structures/tree/tree.js +0 -0
  543. /package/dist/cjs/{types → src/types}/data-structures/trie/index.d.ts +0 -0
  544. /package/dist/cjs/{types → src/types}/data-structures/trie/index.js +0 -0
  545. /package/dist/cjs/{types → src/types}/data-structures/trie/trie.d.ts +0 -0
  546. /package/dist/cjs/{types → src/types}/data-structures/trie/trie.js +0 -0
  547. /package/dist/cjs/{types → src/types}/helpers.d.ts +0 -0
  548. /package/dist/cjs/{types → src/types}/helpers.js +0 -0
  549. /package/dist/cjs/{types → src/types}/index.d.ts +0 -0
  550. /package/dist/cjs/{types → src/types}/index.js +0 -0
  551. /package/dist/cjs/{types → src/types}/utils/index.d.ts +0 -0
  552. /package/dist/cjs/{types → src/types}/utils/index.js +0 -0
  553. /package/dist/cjs/{types → src/types}/utils/utils.d.ts +0 -0
  554. /package/dist/cjs/{types → src/types}/utils/utils.js +0 -0
  555. /package/dist/cjs/{types → src/types}/utils/validate-type.d.ts +0 -0
  556. /package/dist/cjs/{types → src/types}/utils/validate-type.js +0 -0
  557. /package/dist/cjs/{utils → src/utils}/index.d.ts +0 -0
  558. /package/dist/cjs/{utils → src/utils}/index.js +0 -0
  559. /package/dist/cjs/{utils → src/utils}/utils.d.ts +0 -0
  560. /package/dist/cjs/{utils → src/utils}/utils.js +0 -0
  561. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/binary-indexed-tree.d.ts +0 -0
  562. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/binary-indexed-tree.js +0 -0
  563. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/index.d.ts +0 -0
  564. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/index.js +0 -0
  565. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/rb-tree.d.ts +0 -0
  566. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/rb-tree.js +0 -0
  567. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/segment-tree.d.ts +0 -0
  568. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/segment-tree.js +0 -0
  569. /package/dist/mjs/{data-structures → src/data-structures}/graph/abstract-graph.d.ts +0 -0
  570. /package/dist/mjs/{data-structures → src/data-structures}/graph/abstract-graph.js +0 -0
  571. /package/dist/mjs/{data-structures → src/data-structures}/graph/directed-graph.d.ts +0 -0
  572. /package/dist/mjs/{data-structures → src/data-structures}/graph/directed-graph.js +0 -0
  573. /package/dist/mjs/{data-structures → src/data-structures}/graph/index.d.ts +0 -0
  574. /package/dist/mjs/{data-structures → src/data-structures}/graph/index.js +0 -0
  575. /package/dist/mjs/{data-structures → src/data-structures}/graph/map-graph.d.ts +0 -0
  576. /package/dist/mjs/{data-structures → src/data-structures}/graph/map-graph.js +0 -0
  577. /package/dist/mjs/{data-structures → src/data-structures}/graph/undirected-graph.d.ts +0 -0
  578. /package/dist/mjs/{data-structures → src/data-structures}/graph/undirected-graph.js +0 -0
  579. /package/dist/mjs/{data-structures → src/data-structures}/hash/coordinate-map.d.ts +0 -0
  580. /package/dist/mjs/{data-structures → src/data-structures}/hash/coordinate-map.js +0 -0
  581. /package/dist/mjs/{data-structures → src/data-structures}/hash/coordinate-set.d.ts +0 -0
  582. /package/dist/mjs/{data-structures → src/data-structures}/hash/coordinate-set.js +0 -0
  583. /package/dist/mjs/{data-structures → src/data-structures}/hash/hash-map.d.ts +0 -0
  584. /package/dist/mjs/{data-structures → src/data-structures}/hash/hash-map.js +0 -0
  585. /package/dist/mjs/{data-structures → src/data-structures}/hash/hash-table.d.ts +0 -0
  586. /package/dist/mjs/{data-structures → src/data-structures}/hash/hash-table.js +0 -0
  587. /package/dist/mjs/{data-structures → src/data-structures}/hash/index.d.ts +0 -0
  588. /package/dist/mjs/{data-structures → src/data-structures}/hash/index.js +0 -0
  589. /package/dist/mjs/{data-structures → src/data-structures}/hash/tree-map.d.ts +0 -0
  590. /package/dist/mjs/{data-structures → src/data-structures}/hash/tree-map.js +0 -0
  591. /package/dist/mjs/{data-structures → src/data-structures}/hash/tree-set.d.ts +0 -0
  592. /package/dist/mjs/{data-structures → src/data-structures}/hash/tree-set.js +0 -0
  593. /package/dist/mjs/{data-structures → src/data-structures}/heap/heap.d.ts +0 -0
  594. /package/dist/mjs/{data-structures → src/data-structures}/heap/heap.js +0 -0
  595. /package/dist/mjs/{data-structures → src/data-structures}/heap/index.d.ts +0 -0
  596. /package/dist/mjs/{data-structures → src/data-structures}/heap/index.js +0 -0
  597. /package/dist/mjs/{data-structures → src/data-structures}/heap/max-heap.d.ts +0 -0
  598. /package/dist/mjs/{data-structures → src/data-structures}/heap/max-heap.js +0 -0
  599. /package/dist/mjs/{data-structures → src/data-structures}/heap/min-heap.d.ts +0 -0
  600. /package/dist/mjs/{data-structures → src/data-structures}/heap/min-heap.js +0 -0
  601. /package/dist/mjs/{data-structures → src/data-structures}/index.d.ts +0 -0
  602. /package/dist/mjs/{data-structures → src/data-structures}/index.js +0 -0
  603. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/doubly-linked-list.d.ts +0 -0
  604. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/doubly-linked-list.js +0 -0
  605. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/index.d.ts +0 -0
  606. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/index.js +0 -0
  607. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/singly-linked-list.d.ts +0 -0
  608. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/singly-linked-list.js +0 -0
  609. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/skip-linked-list.d.ts +0 -0
  610. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/skip-linked-list.js +0 -0
  611. /package/dist/mjs/{data-structures → src/data-structures}/matrix/index.d.ts +0 -0
  612. /package/dist/mjs/{data-structures → src/data-structures}/matrix/index.js +0 -0
  613. /package/dist/mjs/{data-structures → src/data-structures}/matrix/matrix.d.ts +0 -0
  614. /package/dist/mjs/{data-structures → src/data-structures}/matrix/matrix.js +0 -0
  615. /package/dist/mjs/{data-structures → src/data-structures}/matrix/matrix2d.d.ts +0 -0
  616. /package/dist/mjs/{data-structures → src/data-structures}/matrix/matrix2d.js +0 -0
  617. /package/dist/mjs/{data-structures → src/data-structures}/matrix/navigator.d.ts +0 -0
  618. /package/dist/mjs/{data-structures → src/data-structures}/matrix/navigator.js +0 -0
  619. /package/dist/mjs/{data-structures → src/data-structures}/matrix/vector2d.d.ts +0 -0
  620. /package/dist/mjs/{data-structures → src/data-structures}/matrix/vector2d.js +0 -0
  621. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/index.d.ts +0 -0
  622. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/index.js +0 -0
  623. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/max-priority-queue.d.ts +0 -0
  624. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/max-priority-queue.js +0 -0
  625. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/min-priority-queue.d.ts +0 -0
  626. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/min-priority-queue.js +0 -0
  627. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/priority-queue.d.ts +0 -0
  628. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/priority-queue.js +0 -0
  629. /package/dist/mjs/{data-structures → src/data-structures}/queue/deque.d.ts +0 -0
  630. /package/dist/mjs/{data-structures → src/data-structures}/queue/deque.js +0 -0
  631. /package/dist/mjs/{data-structures → src/data-structures}/queue/index.d.ts +0 -0
  632. /package/dist/mjs/{data-structures → src/data-structures}/queue/index.js +0 -0
  633. /package/dist/mjs/{data-structures → src/data-structures}/queue/queue.d.ts +0 -0
  634. /package/dist/mjs/{data-structures → src/data-structures}/queue/queue.js +0 -0
  635. /package/dist/mjs/{data-structures → src/data-structures}/stack/index.d.ts +0 -0
  636. /package/dist/mjs/{data-structures → src/data-structures}/stack/index.js +0 -0
  637. /package/dist/mjs/{data-structures → src/data-structures}/stack/stack.d.ts +0 -0
  638. /package/dist/mjs/{data-structures → src/data-structures}/stack/stack.js +0 -0
  639. /package/dist/mjs/{data-structures → src/data-structures}/tree/index.d.ts +0 -0
  640. /package/dist/mjs/{data-structures → src/data-structures}/tree/index.js +0 -0
  641. /package/dist/mjs/{data-structures → src/data-structures}/tree/tree.d.ts +0 -0
  642. /package/dist/mjs/{data-structures → src/data-structures}/tree/tree.js +0 -0
  643. /package/dist/mjs/{data-structures → src/data-structures}/trie/index.d.ts +0 -0
  644. /package/dist/mjs/{data-structures → src/data-structures}/trie/index.js +0 -0
  645. /package/dist/mjs/{data-structures → src/data-structures}/trie/trie.d.ts +0 -0
  646. /package/dist/mjs/{data-structures → src/data-structures}/trie/trie.js +0 -0
  647. /package/dist/mjs/{index.d.ts → src/index.d.ts} +0 -0
  648. /package/dist/mjs/{index.js → src/index.js} +0 -0
  649. /package/dist/mjs/{interfaces → src/interfaces}/binary-tree.d.ts +0 -0
  650. /package/dist/mjs/{interfaces → src/interfaces}/binary-tree.js +0 -0
  651. /package/dist/mjs/{interfaces → src/interfaces}/doubly-linked-list.d.ts +0 -0
  652. /package/dist/mjs/{interfaces → src/interfaces}/doubly-linked-list.js +0 -0
  653. /package/dist/mjs/{interfaces → src/interfaces}/graph.d.ts +0 -0
  654. /package/dist/mjs/{interfaces → src/interfaces}/graph.js +0 -0
  655. /package/dist/mjs/{interfaces → src/interfaces}/heap.d.ts +0 -0
  656. /package/dist/mjs/{interfaces → src/interfaces}/heap.js +0 -0
  657. /package/dist/mjs/{interfaces → src/interfaces}/index.d.ts +0 -0
  658. /package/dist/mjs/{interfaces → src/interfaces}/index.js +0 -0
  659. /package/dist/mjs/{interfaces → src/interfaces}/navigator.d.ts +0 -0
  660. /package/dist/mjs/{interfaces → src/interfaces}/navigator.js +0 -0
  661. /package/dist/mjs/{interfaces → src/interfaces}/priority-queue.d.ts +0 -0
  662. /package/dist/mjs/{interfaces → src/interfaces}/priority-queue.js +0 -0
  663. /package/dist/mjs/{interfaces → src/interfaces}/segment-tree.d.ts +0 -0
  664. /package/dist/mjs/{interfaces → src/interfaces}/segment-tree.js +0 -0
  665. /package/dist/mjs/{interfaces → src/interfaces}/singly-linked-list.d.ts +0 -0
  666. /package/dist/mjs/{interfaces → src/interfaces}/singly-linked-list.js +0 -0
  667. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/avl-tree.d.ts +0 -0
  668. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/avl-tree.js +0 -0
  669. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/binary-indexed-tree.d.ts +0 -0
  670. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/binary-indexed-tree.js +0 -0
  671. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/binary-tree.d.ts +0 -0
  672. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/binary-tree.js +0 -0
  673. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/bst.d.ts +0 -0
  674. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/bst.js +0 -0
  675. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/index.d.ts +0 -0
  676. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/index.js +0 -0
  677. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/rb-tree.d.ts +0 -0
  678. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/rb-tree.js +0 -0
  679. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/segment-tree.d.ts +0 -0
  680. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/segment-tree.js +0 -0
  681. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/tree-multiset.d.ts +0 -0
  682. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/tree-multiset.js +0 -0
  683. /package/dist/mjs/{types → src/types}/data-structures/graph/abstract-graph.d.ts +0 -0
  684. /package/dist/mjs/{types → src/types}/data-structures/graph/abstract-graph.js +0 -0
  685. /package/dist/mjs/{types → src/types}/data-structures/graph/directed-graph.d.ts +0 -0
  686. /package/dist/mjs/{types → src/types}/data-structures/graph/directed-graph.js +0 -0
  687. /package/dist/mjs/{types → src/types}/data-structures/graph/index.d.ts +0 -0
  688. /package/dist/mjs/{types → src/types}/data-structures/graph/index.js +0 -0
  689. /package/dist/mjs/{types → src/types}/data-structures/graph/map-graph.d.ts +0 -0
  690. /package/dist/mjs/{types → src/types}/data-structures/graph/map-graph.js +0 -0
  691. /package/dist/mjs/{types → src/types}/data-structures/graph/undirected-graph.d.ts +0 -0
  692. /package/dist/mjs/{types → src/types}/data-structures/graph/undirected-graph.js +0 -0
  693. /package/dist/mjs/{types → src/types}/data-structures/hash/coordinate-map.d.ts +0 -0
  694. /package/dist/mjs/{types → src/types}/data-structures/hash/coordinate-map.js +0 -0
  695. /package/dist/mjs/{types → src/types}/data-structures/hash/coordinate-set.d.ts +0 -0
  696. /package/dist/mjs/{types → src/types}/data-structures/hash/coordinate-set.js +0 -0
  697. /package/dist/mjs/{types → src/types}/data-structures/hash/hash-map.d.ts +0 -0
  698. /package/dist/mjs/{types → src/types}/data-structures/hash/hash-map.js +0 -0
  699. /package/dist/mjs/{types → src/types}/data-structures/hash/hash-table.d.ts +0 -0
  700. /package/dist/mjs/{types → src/types}/data-structures/hash/hash-table.js +0 -0
  701. /package/dist/mjs/{types → src/types}/data-structures/hash/index.d.ts +0 -0
  702. /package/dist/mjs/{types → src/types}/data-structures/hash/index.js +0 -0
  703. /package/dist/mjs/{types → src/types}/data-structures/hash/tree-map.d.ts +0 -0
  704. /package/dist/mjs/{types → src/types}/data-structures/hash/tree-map.js +0 -0
  705. /package/dist/mjs/{types → src/types}/data-structures/hash/tree-set.d.ts +0 -0
  706. /package/dist/mjs/{types → src/types}/data-structures/hash/tree-set.js +0 -0
  707. /package/dist/mjs/{types → src/types}/data-structures/heap/heap.d.ts +0 -0
  708. /package/dist/mjs/{types → src/types}/data-structures/heap/heap.js +0 -0
  709. /package/dist/mjs/{types → src/types}/data-structures/heap/index.d.ts +0 -0
  710. /package/dist/mjs/{types → src/types}/data-structures/heap/index.js +0 -0
  711. /package/dist/mjs/{types → src/types}/data-structures/heap/max-heap.d.ts +0 -0
  712. /package/dist/mjs/{types → src/types}/data-structures/heap/max-heap.js +0 -0
  713. /package/dist/mjs/{types → src/types}/data-structures/heap/min-heap.d.ts +0 -0
  714. /package/dist/mjs/{types → src/types}/data-structures/heap/min-heap.js +0 -0
  715. /package/dist/mjs/{types → src/types}/data-structures/index.d.ts +0 -0
  716. /package/dist/mjs/{types → src/types}/data-structures/index.js +0 -0
  717. /package/dist/mjs/{types → src/types}/data-structures/linked-list/doubly-linked-list.d.ts +0 -0
  718. /package/dist/mjs/{types → src/types}/data-structures/linked-list/doubly-linked-list.js +0 -0
  719. /package/dist/mjs/{types → src/types}/data-structures/linked-list/index.d.ts +0 -0
  720. /package/dist/mjs/{types → src/types}/data-structures/linked-list/index.js +0 -0
  721. /package/dist/mjs/{types → src/types}/data-structures/linked-list/singly-linked-list.d.ts +0 -0
  722. /package/dist/mjs/{types → src/types}/data-structures/linked-list/singly-linked-list.js +0 -0
  723. /package/dist/mjs/{types → src/types}/data-structures/linked-list/skip-linked-list.d.ts +0 -0
  724. /package/dist/mjs/{types → src/types}/data-structures/linked-list/skip-linked-list.js +0 -0
  725. /package/dist/mjs/{types → src/types}/data-structures/matrix/index.d.ts +0 -0
  726. /package/dist/mjs/{types → src/types}/data-structures/matrix/index.js +0 -0
  727. /package/dist/mjs/{types → src/types}/data-structures/matrix/matrix.d.ts +0 -0
  728. /package/dist/mjs/{types → src/types}/data-structures/matrix/matrix.js +0 -0
  729. /package/dist/mjs/{types → src/types}/data-structures/matrix/matrix2d.d.ts +0 -0
  730. /package/dist/mjs/{types → src/types}/data-structures/matrix/matrix2d.js +0 -0
  731. /package/dist/mjs/{types → src/types}/data-structures/matrix/navigator.d.ts +0 -0
  732. /package/dist/mjs/{types → src/types}/data-structures/matrix/navigator.js +0 -0
  733. /package/dist/mjs/{types → src/types}/data-structures/matrix/vector2d.d.ts +0 -0
  734. /package/dist/mjs/{types → src/types}/data-structures/matrix/vector2d.js +0 -0
  735. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/index.d.ts +0 -0
  736. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/index.js +0 -0
  737. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/max-priority-queue.d.ts +0 -0
  738. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/max-priority-queue.js +0 -0
  739. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/min-priority-queue.d.ts +0 -0
  740. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/min-priority-queue.js +0 -0
  741. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/priority-queue.d.ts +0 -0
  742. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/priority-queue.js +0 -0
  743. /package/dist/mjs/{types → src/types}/data-structures/queue/deque.d.ts +0 -0
  744. /package/dist/mjs/{types → src/types}/data-structures/queue/deque.js +0 -0
  745. /package/dist/mjs/{types → src/types}/data-structures/queue/index.d.ts +0 -0
  746. /package/dist/mjs/{types → src/types}/data-structures/queue/index.js +0 -0
  747. /package/dist/mjs/{types → src/types}/data-structures/queue/queue.d.ts +0 -0
  748. /package/dist/mjs/{types → src/types}/data-structures/queue/queue.js +0 -0
  749. /package/dist/mjs/{types → src/types}/data-structures/stack/index.d.ts +0 -0
  750. /package/dist/mjs/{types → src/types}/data-structures/stack/index.js +0 -0
  751. /package/dist/mjs/{types → src/types}/data-structures/stack/stack.d.ts +0 -0
  752. /package/dist/mjs/{types → src/types}/data-structures/stack/stack.js +0 -0
  753. /package/dist/mjs/{types → src/types}/data-structures/tree/index.d.ts +0 -0
  754. /package/dist/mjs/{types → src/types}/data-structures/tree/index.js +0 -0
  755. /package/dist/mjs/{types → src/types}/data-structures/tree/tree.d.ts +0 -0
  756. /package/dist/mjs/{types → src/types}/data-structures/tree/tree.js +0 -0
  757. /package/dist/mjs/{types → src/types}/data-structures/trie/index.d.ts +0 -0
  758. /package/dist/mjs/{types → src/types}/data-structures/trie/index.js +0 -0
  759. /package/dist/mjs/{types → src/types}/data-structures/trie/trie.d.ts +0 -0
  760. /package/dist/mjs/{types → src/types}/data-structures/trie/trie.js +0 -0
  761. /package/dist/mjs/{types → src/types}/helpers.d.ts +0 -0
  762. /package/dist/mjs/{types → src/types}/helpers.js +0 -0
  763. /package/dist/mjs/{types → src/types}/index.d.ts +0 -0
  764. /package/dist/mjs/{types → src/types}/index.js +0 -0
  765. /package/dist/mjs/{types → src/types}/utils/index.d.ts +0 -0
  766. /package/dist/mjs/{types → src/types}/utils/index.js +0 -0
  767. /package/dist/mjs/{types → src/types}/utils/utils.d.ts +0 -0
  768. /package/dist/mjs/{types → src/types}/utils/utils.js +0 -0
  769. /package/dist/mjs/{types → src/types}/utils/validate-type.d.ts +0 -0
  770. /package/dist/mjs/{types → src/types}/utils/validate-type.js +0 -0
  771. /package/dist/mjs/{utils → src/utils}/index.d.ts +0 -0
  772. /package/dist/mjs/{utils → src/utils}/index.js +0 -0
  773. /package/dist/mjs/{utils → src/utils}/utils.d.ts +0 -0
  774. /package/dist/mjs/{utils → src/utils}/utils.js +0 -0
@@ -1,840 +0,0 @@
1
- import {BST, BSTNode, CP, IterationType} from '../../../../src';
2
- import {isDebugTest} from '../../../config';
3
-
4
- const isDebug = isDebugTest;
5
-
6
- describe('BST operations test', () => {
7
- it('should perform various operations on a Binary Search Tree with numeric values', () => {
8
- const bst = new BST();
9
- expect(bst).toBeInstanceOf(BST);
10
- bst.add(11, 11);
11
- bst.add(3, 3);
12
- const idsAndValues = [15, 1, 8, 13, 16, 2, 6, 9, 12, 14, 4, 7, 10, 5];
13
- bst.addMany(idsAndValues, idsAndValues, false);
14
- expect(bst.root).toBeInstanceOf(BSTNode);
15
-
16
- if (bst.root) expect(bst.root.key).toBe(11);
17
-
18
- expect(bst.size).toBe(16);
19
-
20
- expect(bst.has(6)).toBe(true);
21
-
22
- const node6 = bst.getNode(6);
23
- expect(node6 && bst.getHeight(6)).toBe(2);
24
- expect(node6 && bst.getDepth(6)).toBe(3);
25
-
26
- const nodeId10 = bst.getNode(10);
27
- expect(nodeId10?.key).toBe(10);
28
-
29
- const nodeVal9 = bst.getNode(9, node => node.value);
30
- expect(nodeVal9?.key).toBe(9);
31
-
32
- const leftMost = bst.getLeftMost();
33
- expect(leftMost?.key).toBe(1);
34
-
35
- const node15 = bst.getNode(15);
36
- const minNodeBySpecificNode = node15 && bst.getLeftMost(node15);
37
- expect(minNodeBySpecificNode?.key).toBe(12);
38
-
39
- let subTreeSum = 0;
40
- node15 && bst.subTreeTraverse(node => (subTreeSum += node.key), 15);
41
- expect(subTreeSum).toBe(70);
42
-
43
- let lesserSum = 0;
44
- bst.lesserOrGreaterTraverse(node => (lesserSum += node.key), CP.lt, 10);
45
- expect(lesserSum).toBe(45);
46
-
47
- expect(node15).toBeInstanceOf(BSTNode);
48
-
49
- const node11 = bst.getNode(11);
50
- expect(node11).toBeInstanceOf(BSTNode);
51
-
52
- const dfsInorderNodes = bst.dfs(node => node, 'in');
53
- expect(dfsInorderNodes[0].key).toBe(1);
54
- expect(dfsInorderNodes[dfsInorderNodes.length - 1].key).toBe(16);
55
-
56
- bst.perfectlyBalance();
57
- expect(bst.isPerfectlyBalanced()).toBe(true);
58
-
59
- const bfsNodesAfterBalanced: BSTNode<number>[] = [];
60
- bst.bfs(node => bfsNodesAfterBalanced.push(node));
61
- expect(bfsNodesAfterBalanced[0].key).toBe(8);
62
- expect(bfsNodesAfterBalanced[bfsNodesAfterBalanced.length - 1].key).toBe(16);
63
-
64
- const removed11 = bst.delete(11);
65
- expect(removed11).toBeInstanceOf(Array);
66
- expect(removed11[0]).toBeDefined();
67
- expect(removed11[0].deleted).toBeDefined();
68
-
69
- if (removed11[0].deleted) expect(removed11[0].deleted.key).toBe(11);
70
-
71
- expect(bst.isAVLBalanced()).toBe(true);
72
-
73
- expect(bst.getHeight(15)).toBe(1);
74
-
75
- const removed1 = bst.delete(1);
76
- expect(removed1).toBeInstanceOf(Array);
77
- expect(removed1[0]).toBeDefined();
78
- expect(removed1[0].deleted).toBeDefined();
79
- if (removed1[0].deleted) expect(removed1[0].deleted.key).toBe(1);
80
-
81
- expect(bst.isAVLBalanced()).toBe(true);
82
-
83
- expect(bst.getHeight()).toBe(4);
84
-
85
- const removed4 = bst.delete(4);
86
- expect(removed4).toBeInstanceOf(Array);
87
- expect(removed4[0]).toBeDefined();
88
- expect(removed4[0].deleted).toBeDefined();
89
- if (removed4[0].deleted) expect(removed4[0].deleted.key).toBe(4);
90
- expect(bst.isAVLBalanced()).toBe(true);
91
- expect(bst.getHeight()).toBe(4);
92
-
93
- const removed10 = bst.delete(10);
94
- expect(removed10).toBeInstanceOf(Array);
95
- expect(removed10[0]).toBeDefined();
96
- expect(removed10[0].deleted).toBeDefined();
97
- if (removed10[0].deleted) expect(removed10[0].deleted.key).toBe(10);
98
- expect(bst.isAVLBalanced()).toBe(false);
99
- expect(bst.getHeight()).toBe(4);
100
-
101
- const removed15 = bst.delete(15);
102
- expect(removed15).toBeInstanceOf(Array);
103
- expect(removed15[0]).toBeDefined();
104
- expect(removed15[0].deleted).toBeDefined();
105
- if (removed15[0].deleted) expect(removed15[0].deleted.key).toBe(15);
106
-
107
- expect(bst.isAVLBalanced()).toBe(true);
108
- expect(bst.getHeight()).toBe(3);
109
-
110
- const removed5 = bst.delete(5);
111
- expect(removed5).toBeInstanceOf(Array);
112
- expect(removed5[0]).toBeDefined();
113
- expect(removed5[0].deleted).toBeDefined();
114
- if (removed5[0].deleted) expect(removed5[0].deleted.key).toBe(5);
115
-
116
- expect(bst.isAVLBalanced()).toBe(true);
117
- expect(bst.getHeight()).toBe(3);
118
-
119
- const removed13 = bst.delete(13);
120
- expect(removed13).toBeInstanceOf(Array);
121
- expect(removed13[0]).toBeDefined();
122
- expect(removed13[0].deleted).toBeDefined();
123
- if (removed13[0].deleted) expect(removed13[0].deleted.key).toBe(13);
124
- expect(bst.isAVLBalanced()).toBe(true);
125
- expect(bst.getHeight()).toBe(3);
126
-
127
- const removed3 = bst.delete(3);
128
- expect(removed3).toBeInstanceOf(Array);
129
- expect(removed3[0]).toBeDefined();
130
- expect(removed3[0].deleted).toBeDefined();
131
- if (removed3[0].deleted) expect(removed3[0].deleted.key).toBe(3);
132
- expect(bst.isAVLBalanced()).toBe(false);
133
- expect(bst.getHeight()).toBe(3);
134
-
135
- const removed8 = bst.delete(8);
136
- expect(removed8).toBeInstanceOf(Array);
137
- expect(removed8[0]).toBeDefined();
138
- expect(removed8[0].deleted).toBeDefined();
139
- if (removed8[0].deleted) expect(removed8[0].deleted.key).toBe(8);
140
- expect(bst.isAVLBalanced()).toBe(true);
141
- expect(bst.getHeight()).toBe(3);
142
-
143
- const removed6 = bst.delete(6);
144
- expect(removed6).toBeInstanceOf(Array);
145
- expect(removed6[0]).toBeDefined();
146
- expect(removed6[0].deleted).toBeDefined();
147
- if (removed6[0].deleted) expect(removed6[0].deleted.key).toBe(6);
148
- expect(bst.delete(6).length).toBe(0);
149
- expect(bst.isAVLBalanced()).toBe(false);
150
- expect(bst.getHeight()).toBe(3);
151
-
152
- const removed7 = bst.delete(7);
153
- expect(removed7).toBeInstanceOf(Array);
154
- expect(removed7[0]).toBeDefined();
155
- expect(removed7[0].deleted).toBeDefined();
156
- if (removed7[0].deleted) expect(removed7[0].deleted.key).toBe(7);
157
- expect(bst.isAVLBalanced()).toBe(false);
158
- expect(bst.getHeight()).toBe(3);
159
-
160
- const removed9 = bst.delete(9);
161
- expect(removed9).toBeInstanceOf(Array);
162
- expect(removed9[0]).toBeDefined();
163
- expect(removed9[0].deleted).toBeDefined();
164
- if (removed9[0].deleted) expect(removed9[0].deleted.key).toBe(9);
165
- expect(bst.isAVLBalanced()).toBe(false);
166
- expect(bst.getHeight()).toBe(3);
167
-
168
- const removed14 = bst.delete(14);
169
- expect(removed14).toBeInstanceOf(Array);
170
- expect(removed14[0]).toBeDefined();
171
- expect(removed14[0].deleted).toBeDefined();
172
- if (removed14[0].deleted) expect(removed14[0].deleted.key).toBe(14);
173
- expect(bst.isAVLBalanced()).toBe(false);
174
- expect(bst.getHeight()).toBe(2);
175
-
176
- expect(bst.isAVLBalanced()).toBe(false);
177
-
178
- const bfsIDs: number[] = [];
179
- bst.bfs(node => bfsIDs.push(node.key));
180
- expect(bfsIDs[0]).toBe(2);
181
- expect(bfsIDs[1]).toBe(12);
182
- expect(bfsIDs[2]).toBe(16);
183
-
184
- const bfsNodes: BSTNode<number>[] = [];
185
- bst.bfs(node => bfsNodes.push(node));
186
- expect(bfsNodes[0].key).toBe(2);
187
- expect(bfsNodes[1].key).toBe(12);
188
- expect(bfsNodes[2].key).toBe(16);
189
- });
190
-
191
- it('should perform various operations on a Binary Search Tree with object values', () => {
192
- const objBST = new BST<{key: number; keyA: number}>();
193
- expect(objBST).toBeInstanceOf(BST);
194
- objBST.add(11, {key: 11, keyA: 11});
195
- objBST.add(3, {key: 3, keyA: 3});
196
- const values = [
197
- {key: 15, keyA: 15},
198
- {key: 1, keyA: 1},
199
- {key: 8, keyA: 8},
200
- {key: 13, keyA: 13},
201
- {key: 16, keyA: 16},
202
- {key: 2, keyA: 2},
203
- {key: 6, keyA: 6},
204
- {key: 9, keyA: 9},
205
- {key: 12, keyA: 12},
206
- {key: 14, keyA: 14},
207
- {key: 4, keyA: 4},
208
- {key: 7, keyA: 7},
209
- {key: 10, keyA: 10},
210
- {key: 5, keyA: 5}
211
- ];
212
-
213
- objBST.addMany(
214
- values.map(item => item.key),
215
- values,
216
- false
217
- );
218
-
219
- expect(objBST.root).toBeInstanceOf(BSTNode);
220
-
221
- if (objBST.root) expect(objBST.root.key).toBe(11);
222
-
223
- expect(objBST.has(6)).toBe(true);
224
-
225
- const node6 = objBST.getNode(6);
226
- expect(node6 && objBST.getHeight(node6)).toBe(2);
227
- expect(node6 && objBST.getDepth(node6)).toBe(3);
228
-
229
- const nodeId10 = objBST.getNode(10);
230
- expect(nodeId10?.key).toBe(10);
231
-
232
- const nodeVal9 = objBST.getNode(9);
233
- expect(nodeVal9?.key).toBe(9);
234
-
235
- const leftMost = objBST.getLeftMost();
236
- expect(leftMost?.key).toBe(1);
237
-
238
- const node15 = objBST.getNode(15);
239
- expect(node15?.value).toEqual({key: 15, keyA: 15});
240
- const minNodeBySpecificNode = node15 && objBST.getLeftMost(node15);
241
- expect(minNodeBySpecificNode?.key).toBe(12);
242
-
243
- let subTreeSum = 0;
244
- node15 && objBST.subTreeTraverse(node => (subTreeSum += node.key), node15);
245
- expect(subTreeSum).toBe(70);
246
-
247
- let lesserSum = 0;
248
- objBST.lesserOrGreaterTraverse(node => (lesserSum += node.key), CP.lt, 10);
249
- expect(lesserSum).toBe(45);
250
-
251
- expect(node15).toBeInstanceOf(BSTNode);
252
-
253
- const node11 = objBST.getNode(11);
254
- expect(node11).toBeInstanceOf(BSTNode);
255
-
256
- const dfsInorderNodes = objBST.dfs(node => node, 'in');
257
- expect(dfsInorderNodes[0].key).toBe(1);
258
- expect(dfsInorderNodes[dfsInorderNodes.length - 1].key).toBe(16);
259
-
260
- objBST.perfectlyBalance();
261
- expect(objBST.isPerfectlyBalanced()).toBe(true);
262
-
263
- const bfsNodesAfterBalanced: BSTNode<{key: number; keyA: number}>[] = [];
264
- objBST.bfs(node => bfsNodesAfterBalanced.push(node));
265
- expect(bfsNodesAfterBalanced[0].key).toBe(8);
266
- expect(bfsNodesAfterBalanced[bfsNodesAfterBalanced.length - 1].key).toBe(16);
267
-
268
- const removed11 = objBST.delete(11);
269
- expect(removed11).toBeInstanceOf(Array);
270
- expect(removed11[0]).toBeDefined();
271
- expect(removed11[0].deleted).toBeDefined();
272
-
273
- if (removed11[0].deleted) expect(removed11[0].deleted.key).toBe(11);
274
-
275
- expect(objBST.isAVLBalanced()).toBe(true);
276
-
277
- expect(node15 && objBST.getHeight(node15)).toBe(2);
278
-
279
- const removed1 = objBST.delete(1);
280
- expect(removed1).toBeInstanceOf(Array);
281
- expect(removed1[0]).toBeDefined();
282
- expect(removed1[0].deleted).toBeDefined();
283
- if (removed1[0].deleted) expect(removed1[0].deleted.key).toBe(1);
284
-
285
- expect(objBST.isAVLBalanced()).toBe(true);
286
-
287
- expect(objBST.getHeight()).toBe(4);
288
-
289
- const removed4 = objBST.delete(4);
290
- expect(removed4).toBeInstanceOf(Array);
291
- expect(removed4[0]).toBeDefined();
292
- expect(removed4[0].deleted).toBeDefined();
293
- if (removed4[0].deleted) expect(removed4[0].deleted.key).toBe(4);
294
- expect(objBST.isAVLBalanced()).toBe(true);
295
- expect(objBST.getHeight()).toBe(4);
296
-
297
- const removed10 = objBST.delete(10);
298
- expect(removed10).toBeInstanceOf(Array);
299
- expect(removed10[0]).toBeDefined();
300
- expect(removed10[0].deleted).toBeDefined();
301
- if (removed10[0].deleted) expect(removed10[0].deleted.key).toBe(10);
302
- expect(objBST.isAVLBalanced()).toBe(false);
303
- expect(objBST.getHeight()).toBe(4);
304
-
305
- const removed15 = objBST.delete(15);
306
- expect(removed15).toBeInstanceOf(Array);
307
- expect(removed15[0]).toBeDefined();
308
- expect(removed15[0].deleted).toBeDefined();
309
- if (removed15[0].deleted) expect(removed15[0].deleted.key).toBe(15);
310
-
311
- expect(objBST.isAVLBalanced()).toBe(true);
312
- expect(objBST.getHeight()).toBe(3);
313
-
314
- const removed5 = objBST.delete(5);
315
- expect(removed5).toBeInstanceOf(Array);
316
- expect(removed5[0]).toBeDefined();
317
- expect(removed5[0].deleted).toBeDefined();
318
- if (removed5[0].deleted) expect(removed5[0].deleted.key).toBe(5);
319
-
320
- expect(objBST.isAVLBalanced()).toBe(true);
321
- expect(objBST.getHeight()).toBe(3);
322
-
323
- const removed13 = objBST.delete(13);
324
- expect(removed13).toBeInstanceOf(Array);
325
- expect(removed13[0]).toBeDefined();
326
- expect(removed13[0].deleted).toBeDefined();
327
- if (removed13[0].deleted) expect(removed13[0].deleted.key).toBe(13);
328
- expect(objBST.isAVLBalanced()).toBe(true);
329
- expect(objBST.getHeight()).toBe(3);
330
-
331
- const removed3 = objBST.delete(3);
332
- expect(removed3).toBeInstanceOf(Array);
333
- expect(removed3[0]).toBeDefined();
334
- expect(removed3[0].deleted).toBeDefined();
335
- if (removed3[0].deleted) expect(removed3[0].deleted.key).toBe(3);
336
- expect(objBST.isAVLBalanced()).toBe(false);
337
- expect(objBST.getHeight()).toBe(3);
338
-
339
- const removed8 = objBST.delete(8);
340
- expect(removed8).toBeInstanceOf(Array);
341
- expect(removed8[0]).toBeDefined();
342
- expect(removed8[0].deleted).toBeDefined();
343
- if (removed8[0].deleted) expect(removed8[0].deleted.key).toBe(8);
344
- expect(objBST.isAVLBalanced()).toBe(true);
345
- expect(objBST.getHeight()).toBe(3);
346
-
347
- const removed6 = objBST.delete(6);
348
- expect(removed6).toBeInstanceOf(Array);
349
- expect(removed6[0]).toBeDefined();
350
- expect(removed6[0].deleted).toBeDefined();
351
- if (removed6[0].deleted) expect(removed6[0].deleted.key).toBe(6);
352
- expect(objBST.delete(6).length).toBe(0);
353
- expect(objBST.isAVLBalanced()).toBe(false);
354
- expect(objBST.getHeight()).toBe(3);
355
-
356
- const removed7 = objBST.delete(7);
357
- expect(removed7).toBeInstanceOf(Array);
358
- expect(removed7[0]).toBeDefined();
359
- expect(removed7[0].deleted).toBeDefined();
360
- if (removed7[0].deleted) expect(removed7[0].deleted.key).toBe(7);
361
- expect(objBST.isAVLBalanced()).toBe(false);
362
- expect(objBST.getHeight()).toBe(3);
363
-
364
- const removed9 = objBST.delete(9);
365
- expect(removed9).toBeInstanceOf(Array);
366
- expect(removed9[0]).toBeDefined();
367
- expect(removed9[0].deleted).toBeDefined();
368
- if (removed9[0].deleted) expect(removed9[0].deleted.key).toBe(9);
369
- expect(objBST.isAVLBalanced()).toBe(false);
370
- expect(objBST.getHeight()).toBe(3);
371
-
372
- const removed14 = objBST.delete(14);
373
- expect(removed14).toBeInstanceOf(Array);
374
- expect(removed14[0]).toBeDefined();
375
- expect(removed14[0].deleted).toBeDefined();
376
- if (removed14[0].deleted) expect(removed14[0].deleted.key).toBe(14);
377
- expect(objBST.isAVLBalanced()).toBe(false);
378
- expect(objBST.getHeight()).toBe(2);
379
-
380
- expect(objBST.isAVLBalanced()).toBe(false);
381
-
382
- const bfsIDs: number[] = [];
383
- objBST.bfs(node => bfsIDs.push(node.key));
384
- expect(bfsIDs[0]).toBe(2);
385
- expect(bfsIDs[1]).toBe(12);
386
- expect(bfsIDs[2]).toBe(16);
387
-
388
- const bfsNodes: BSTNode<{key: number; keyA: number}>[] = [];
389
- objBST.bfs(node => bfsNodes.push(node));
390
- expect(bfsNodes[0].key).toBe(2);
391
- expect(bfsNodes[1].key).toBe(12);
392
- expect(bfsNodes[2].key).toBe(16);
393
- });
394
- });
395
-
396
- describe('BST operations test recursively', () => {
397
- it('should perform various operations on a Binary Search Tree with numeric values', () => {
398
- const bst = new BST({iterationType: IterationType.RECURSIVE});
399
- expect(bst).toBeInstanceOf(BST);
400
- bst.add(11, 11);
401
- bst.add(3, 3);
402
- const idsAndValues = [15, 1, 8, 13, 16, 2, 6, 9, 12, 14, 4, 7, 10, 5];
403
- bst.addMany(idsAndValues, idsAndValues, false);
404
- expect(bst.root).toBeInstanceOf(BSTNode);
405
-
406
- if (bst.root) expect(bst.root.key).toBe(11);
407
-
408
- expect(bst.size).toBe(16);
409
-
410
- expect(bst.has(6)).toBe(true);
411
-
412
- const node6 = bst.getNode(6);
413
- expect(node6 && bst.getHeight(6)).toBe(2);
414
- expect(node6 && bst.getDepth(6)).toBe(3);
415
-
416
- const nodeId10 = bst.getNode(10);
417
- expect(bst.get(10)).toBe(10);
418
- expect(nodeId10?.key).toBe(10);
419
-
420
- const nodeVal9 = bst.getNode(9, node => node.value);
421
- expect(nodeVal9?.key).toBe(9);
422
-
423
- const leftMost = bst.getLeftMost();
424
- expect(leftMost?.key).toBe(1);
425
-
426
- const node15 = bst.getNode(15);
427
- const minNodeBySpecificNode = node15 && bst.getLeftMost(node15);
428
- expect(minNodeBySpecificNode?.key).toBe(12);
429
-
430
- let subTreeSum = 0;
431
- node15 && bst.subTreeTraverse(node => (subTreeSum += node.key), 15);
432
- expect(subTreeSum).toBe(70);
433
-
434
- let lesserSum = 0;
435
- bst.lesserOrGreaterTraverse(node => (lesserSum += node.key), CP.lt, 10);
436
- expect(lesserSum).toBe(45);
437
-
438
- expect(node15).toBeInstanceOf(BSTNode);
439
-
440
- const node11 = bst.getNode(11);
441
- expect(node11).toBeInstanceOf(BSTNode);
442
-
443
- const dfsInorderNodes = bst.dfs(node => node, 'in');
444
- expect(dfsInorderNodes[0].key).toBe(1);
445
- expect(dfsInorderNodes[dfsInorderNodes.length - 1].key).toBe(16);
446
-
447
- bst.perfectlyBalance();
448
- expect(bst.isPerfectlyBalanced()).toBe(true);
449
-
450
- const bfsNodesAfterBalanced: BSTNode<number>[] = [];
451
- bst.bfs(node => bfsNodesAfterBalanced.push(node));
452
- expect(bfsNodesAfterBalanced[0].key).toBe(8);
453
- expect(bfsNodesAfterBalanced[bfsNodesAfterBalanced.length - 1].key).toBe(16);
454
-
455
- const removed11 = bst.delete(11);
456
- expect(removed11).toBeInstanceOf(Array);
457
- expect(removed11[0]).toBeDefined();
458
- expect(removed11[0].deleted).toBeDefined();
459
-
460
- if (removed11[0].deleted) expect(removed11[0].deleted.key).toBe(11);
461
-
462
- expect(bst.isAVLBalanced()).toBe(true);
463
-
464
- expect(bst.getHeight(15)).toBe(1);
465
-
466
- const removed1 = bst.delete(1);
467
- expect(removed1).toBeInstanceOf(Array);
468
- expect(removed1[0]).toBeDefined();
469
- expect(removed1[0].deleted).toBeDefined();
470
- if (removed1[0].deleted) expect(removed1[0].deleted.key).toBe(1);
471
-
472
- expect(bst.isAVLBalanced()).toBe(true);
473
-
474
- expect(bst.getHeight()).toBe(4);
475
-
476
- const removed4 = bst.delete(4);
477
- expect(removed4).toBeInstanceOf(Array);
478
- expect(removed4[0]).toBeDefined();
479
- expect(removed4[0].deleted).toBeDefined();
480
- if (removed4[0].deleted) expect(removed4[0].deleted.key).toBe(4);
481
- expect(bst.isAVLBalanced()).toBe(true);
482
- expect(bst.getHeight()).toBe(4);
483
-
484
- const removed10 = bst.delete(10);
485
- expect(removed10).toBeInstanceOf(Array);
486
- expect(removed10[0]).toBeDefined();
487
- expect(removed10[0].deleted).toBeDefined();
488
- if (removed10[0].deleted) expect(removed10[0].deleted.key).toBe(10);
489
- expect(bst.isAVLBalanced()).toBe(false);
490
- expect(bst.getHeight()).toBe(4);
491
-
492
- const removed15 = bst.delete(15);
493
- expect(removed15).toBeInstanceOf(Array);
494
- expect(removed15[0]).toBeDefined();
495
- expect(removed15[0].deleted).toBeDefined();
496
- if (removed15[0].deleted) expect(removed15[0].deleted.key).toBe(15);
497
-
498
- expect(bst.isAVLBalanced()).toBe(true);
499
- expect(bst.getHeight()).toBe(3);
500
-
501
- const removed5 = bst.delete(5);
502
- expect(removed5).toBeInstanceOf(Array);
503
- expect(removed5[0]).toBeDefined();
504
- expect(removed5[0].deleted).toBeDefined();
505
- if (removed5[0].deleted) expect(removed5[0].deleted.key).toBe(5);
506
-
507
- expect(bst.isAVLBalanced()).toBe(true);
508
- expect(bst.getHeight()).toBe(3);
509
-
510
- const removed13 = bst.delete(13);
511
- expect(removed13).toBeInstanceOf(Array);
512
- expect(removed13[0]).toBeDefined();
513
- expect(removed13[0].deleted).toBeDefined();
514
- if (removed13[0].deleted) expect(removed13[0].deleted.key).toBe(13);
515
- expect(bst.isAVLBalanced()).toBe(true);
516
- expect(bst.getHeight()).toBe(3);
517
-
518
- const removed3 = bst.delete(3);
519
- expect(removed3).toBeInstanceOf(Array);
520
- expect(removed3[0]).toBeDefined();
521
- expect(removed3[0].deleted).toBeDefined();
522
- if (removed3[0].deleted) expect(removed3[0].deleted.key).toBe(3);
523
- expect(bst.isAVLBalanced()).toBe(false);
524
- expect(bst.getHeight()).toBe(3);
525
-
526
- const removed8 = bst.delete(8);
527
- expect(removed8).toBeInstanceOf(Array);
528
- expect(removed8[0]).toBeDefined();
529
- expect(removed8[0].deleted).toBeDefined();
530
- if (removed8[0].deleted) expect(removed8[0].deleted.key).toBe(8);
531
- expect(bst.isAVLBalanced()).toBe(true);
532
- expect(bst.getHeight()).toBe(3);
533
-
534
- const removed6 = bst.delete(6);
535
- expect(removed6).toBeInstanceOf(Array);
536
- expect(removed6[0]).toBeDefined();
537
- expect(removed6[0].deleted).toBeDefined();
538
- if (removed6[0].deleted) expect(removed6[0].deleted.key).toBe(6);
539
- expect(bst.delete(6).length).toBe(0);
540
- expect(bst.isAVLBalanced()).toBe(false);
541
- expect(bst.getHeight()).toBe(3);
542
-
543
- const removed7 = bst.delete(7);
544
- expect(removed7).toBeInstanceOf(Array);
545
- expect(removed7[0]).toBeDefined();
546
- expect(removed7[0].deleted).toBeDefined();
547
- if (removed7[0].deleted) expect(removed7[0].deleted.key).toBe(7);
548
- expect(bst.isAVLBalanced()).toBe(false);
549
- expect(bst.getHeight()).toBe(3);
550
-
551
- const removed9 = bst.delete(9);
552
- expect(removed9).toBeInstanceOf(Array);
553
- expect(removed9[0]).toBeDefined();
554
- expect(removed9[0].deleted).toBeDefined();
555
- if (removed9[0].deleted) expect(removed9[0].deleted.key).toBe(9);
556
- expect(bst.isAVLBalanced()).toBe(false);
557
- expect(bst.getHeight()).toBe(3);
558
-
559
- const removed14 = bst.delete(14);
560
- expect(removed14).toBeInstanceOf(Array);
561
- expect(removed14[0]).toBeDefined();
562
- expect(removed14[0].deleted).toBeDefined();
563
- if (removed14[0].deleted) expect(removed14[0].deleted.key).toBe(14);
564
- expect(bst.isAVLBalanced()).toBe(false);
565
- expect(bst.getHeight()).toBe(2);
566
-
567
- expect(bst.isAVLBalanced()).toBe(false);
568
-
569
- const bfsIDs: number[] = [];
570
- bst.bfs(node => bfsIDs.push(node.key));
571
- expect(bfsIDs[0]).toBe(2);
572
- expect(bfsIDs[1]).toBe(12);
573
- expect(bfsIDs[2]).toBe(16);
574
-
575
- const bfsNodes: BSTNode<number>[] = [];
576
- bst.bfs(node => bfsNodes.push(node));
577
- expect(bfsNodes[0].key).toBe(2);
578
- expect(bfsNodes[1].key).toBe(12);
579
- expect(bfsNodes[2].key).toBe(16);
580
- });
581
-
582
- it('should perform various operations on a Binary Search Tree with object values', () => {
583
- const objBST = new BST<{key: number; keyA: number}>();
584
- expect(objBST).toBeInstanceOf(BST);
585
- objBST.add(11, {key: 11, keyA: 11});
586
- objBST.add(3, {key: 3, keyA: 3});
587
- const values = [
588
- {key: 15, keyA: 15},
589
- {key: 1, keyA: 1},
590
- {key: 8, keyA: 8},
591
- {key: 13, keyA: 13},
592
- {key: 16, keyA: 16},
593
- {key: 2, keyA: 2},
594
- {key: 6, keyA: 6},
595
- {key: 9, keyA: 9},
596
- {key: 12, keyA: 12},
597
- {key: 14, keyA: 14},
598
- {key: 4, keyA: 4},
599
- {key: 7, keyA: 7},
600
- {key: 10, keyA: 10},
601
- {key: 5, keyA: 5}
602
- ];
603
-
604
- objBST.addMany(
605
- values.map(item => item.key),
606
- values,
607
- false
608
- );
609
-
610
- expect(objBST.root).toBeInstanceOf(BSTNode);
611
-
612
- if (objBST.root) expect(objBST.root.key).toBe(11);
613
-
614
- expect(objBST.has(6)).toBe(true);
615
-
616
- const node6 = objBST.getNode(6);
617
- expect(objBST.get(6)).toEqual({key: 6, keyA: 6});
618
- expect(node6 && objBST.getHeight(node6)).toBe(2);
619
- expect(node6 && objBST.getDepth(node6)).toBe(3);
620
-
621
- const nodeId10 = objBST.getNode(10);
622
- expect(nodeId10?.key).toBe(10);
623
-
624
- const nodeVal9 = objBST.getNode(9);
625
- expect(nodeVal9?.key).toBe(9);
626
-
627
- const leftMost = objBST.getLeftMost();
628
- expect(leftMost?.key).toBe(1);
629
-
630
- const node15 = objBST.getNode(15);
631
- expect(node15?.value).toEqual({key: 15, keyA: 15});
632
- const minNodeBySpecificNode = node15 && objBST.getLeftMost(node15);
633
- expect(minNodeBySpecificNode?.key).toBe(12);
634
-
635
- let subTreeSum = 0;
636
- node15 && objBST.subTreeTraverse(node => (subTreeSum += node.key), node15);
637
- expect(subTreeSum).toBe(70);
638
-
639
- let lesserSum = 0;
640
- objBST.lesserOrGreaterTraverse(node => (lesserSum += node.key), CP.lt, 10);
641
- expect(lesserSum).toBe(45);
642
-
643
- expect(node15).toBeInstanceOf(BSTNode);
644
-
645
- const node11 = objBST.getNode(11);
646
- expect(node11).toBeInstanceOf(BSTNode);
647
-
648
- const dfsInorderNodes = objBST.dfs(node => node, 'in');
649
- expect(dfsInorderNodes[0].key).toBe(1);
650
- expect(dfsInorderNodes[dfsInorderNodes.length - 1].key).toBe(16);
651
-
652
- objBST.perfectlyBalance();
653
- expect(objBST.isPerfectlyBalanced()).toBe(true);
654
-
655
- const bfsNodesAfterBalanced: BSTNode<{key: number; keyA: number}>[] = [];
656
- objBST.bfs(node => bfsNodesAfterBalanced.push(node));
657
- expect(bfsNodesAfterBalanced[0].key).toBe(8);
658
- expect(bfsNodesAfterBalanced[bfsNodesAfterBalanced.length - 1].key).toBe(16);
659
-
660
- const removed11 = objBST.delete(11);
661
- expect(removed11).toBeInstanceOf(Array);
662
- expect(removed11[0]).toBeDefined();
663
- expect(removed11[0].deleted).toBeDefined();
664
-
665
- if (removed11[0].deleted) expect(removed11[0].deleted.key).toBe(11);
666
-
667
- expect(objBST.isAVLBalanced()).toBe(true);
668
-
669
- expect(node15 && objBST.getHeight(node15)).toBe(2);
670
-
671
- const removed1 = objBST.delete(1);
672
- expect(removed1).toBeInstanceOf(Array);
673
- expect(removed1[0]).toBeDefined();
674
- expect(removed1[0].deleted).toBeDefined();
675
- if (removed1[0].deleted) expect(removed1[0].deleted.key).toBe(1);
676
-
677
- expect(objBST.isAVLBalanced()).toBe(true);
678
-
679
- expect(objBST.getHeight()).toBe(4);
680
-
681
- const removed4 = objBST.delete(4);
682
- expect(removed4).toBeInstanceOf(Array);
683
- expect(removed4[0]).toBeDefined();
684
- expect(removed4[0].deleted).toBeDefined();
685
- if (removed4[0].deleted) expect(removed4[0].deleted.key).toBe(4);
686
- expect(objBST.isAVLBalanced()).toBe(true);
687
- expect(objBST.getHeight()).toBe(4);
688
-
689
- const removed10 = objBST.delete(10);
690
- expect(removed10).toBeInstanceOf(Array);
691
- expect(removed10[0]).toBeDefined();
692
- expect(removed10[0].deleted).toBeDefined();
693
- if (removed10[0].deleted) expect(removed10[0].deleted.key).toBe(10);
694
- expect(objBST.isAVLBalanced()).toBe(false);
695
- expect(objBST.getHeight()).toBe(4);
696
-
697
- const removed15 = objBST.delete(15);
698
- expect(removed15).toBeInstanceOf(Array);
699
- expect(removed15[0]).toBeDefined();
700
- expect(removed15[0].deleted).toBeDefined();
701
- if (removed15[0].deleted) expect(removed15[0].deleted.key).toBe(15);
702
-
703
- expect(objBST.isAVLBalanced()).toBe(true);
704
- expect(objBST.getHeight()).toBe(3);
705
-
706
- const removed5 = objBST.delete(5);
707
- expect(removed5).toBeInstanceOf(Array);
708
- expect(removed5[0]).toBeDefined();
709
- expect(removed5[0].deleted).toBeDefined();
710
- if (removed5[0].deleted) expect(removed5[0].deleted.key).toBe(5);
711
-
712
- expect(objBST.isAVLBalanced()).toBe(true);
713
- expect(objBST.getHeight()).toBe(3);
714
-
715
- const removed13 = objBST.delete(13);
716
- expect(removed13).toBeInstanceOf(Array);
717
- expect(removed13[0]).toBeDefined();
718
- expect(removed13[0].deleted).toBeDefined();
719
- if (removed13[0].deleted) expect(removed13[0].deleted.key).toBe(13);
720
- expect(objBST.isAVLBalanced()).toBe(true);
721
- expect(objBST.getHeight()).toBe(3);
722
-
723
- const removed3 = objBST.delete(3);
724
- expect(removed3).toBeInstanceOf(Array);
725
- expect(removed3[0]).toBeDefined();
726
- expect(removed3[0].deleted).toBeDefined();
727
- if (removed3[0].deleted) expect(removed3[0].deleted.key).toBe(3);
728
- expect(objBST.isAVLBalanced()).toBe(false);
729
- expect(objBST.getHeight()).toBe(3);
730
-
731
- const removed8 = objBST.delete(8);
732
- expect(removed8).toBeInstanceOf(Array);
733
- expect(removed8[0]).toBeDefined();
734
- expect(removed8[0].deleted).toBeDefined();
735
- if (removed8[0].deleted) expect(removed8[0].deleted.key).toBe(8);
736
- expect(objBST.isAVLBalanced()).toBe(true);
737
- expect(objBST.getHeight()).toBe(3);
738
-
739
- const removed6 = objBST.delete(6);
740
- expect(removed6).toBeInstanceOf(Array);
741
- expect(removed6[0]).toBeDefined();
742
- expect(removed6[0].deleted).toBeDefined();
743
- if (removed6[0].deleted) expect(removed6[0].deleted.key).toBe(6);
744
- expect(objBST.delete(6).length).toBe(0);
745
- expect(objBST.isAVLBalanced()).toBe(false);
746
- expect(objBST.getHeight()).toBe(3);
747
-
748
- const removed7 = objBST.delete(7);
749
- expect(removed7).toBeInstanceOf(Array);
750
- expect(removed7[0]).toBeDefined();
751
- expect(removed7[0].deleted).toBeDefined();
752
- if (removed7[0].deleted) expect(removed7[0].deleted.key).toBe(7);
753
- expect(objBST.isAVLBalanced()).toBe(false);
754
- expect(objBST.getHeight()).toBe(3);
755
-
756
- const removed9 = objBST.delete(9);
757
- expect(removed9).toBeInstanceOf(Array);
758
- expect(removed9[0]).toBeDefined();
759
- expect(removed9[0].deleted).toBeDefined();
760
- if (removed9[0].deleted) expect(removed9[0].deleted.key).toBe(9);
761
- expect(objBST.isAVLBalanced()).toBe(false);
762
- expect(objBST.getHeight()).toBe(3);
763
-
764
- const removed14 = objBST.delete(14);
765
- expect(removed14).toBeInstanceOf(Array);
766
- expect(removed14[0]).toBeDefined();
767
- expect(removed14[0].deleted).toBeDefined();
768
- if (removed14[0].deleted) expect(removed14[0].deleted.key).toBe(14);
769
- expect(objBST.isAVLBalanced()).toBe(false);
770
- expect(objBST.getHeight()).toBe(2);
771
-
772
- expect(objBST.isAVLBalanced()).toBe(false);
773
-
774
- const bfsIDs: number[] = [];
775
- objBST.bfs(node => bfsIDs.push(node.key));
776
- expect(bfsIDs[0]).toBe(2);
777
- expect(bfsIDs[1]).toBe(12);
778
- expect(bfsIDs[2]).toBe(16);
779
-
780
- const bfsNodes: BSTNode<{key: number; keyA: number}>[] = [];
781
- objBST.bfs(node => bfsNodes.push(node));
782
- expect(bfsNodes[0].key).toBe(2);
783
- expect(bfsNodes[1].key).toBe(12);
784
- expect(bfsNodes[2].key).toBe(16);
785
- });
786
- });
787
-
788
- describe('BST Performance test', function () {
789
- const bst = new BST<BSTNode<number>>();
790
- const inputSize = 10000; // Adjust input sizes as needed
791
-
792
- beforeEach(() => {
793
- bst.clear();
794
- });
795
-
796
- it(`Observe the time consumption of BST.dfs be good`, function () {
797
- const startDFS = performance.now();
798
- const dfs = bst.dfs(node => node);
799
- isDebug && console.log('---bfs', performance.now() - startDFS, dfs.length);
800
- });
801
-
802
- it('Should the time consumption of lesserOrGreaterTraverse fitting O(n log n)', function () {
803
- const nodes: number[] = [];
804
- for (let i = 0; i < inputSize; i++) {
805
- nodes.push(i);
806
- }
807
- const start = performance.now();
808
- bst.addMany(nodes);
809
- isDebug && console.log('---add', performance.now() - start);
810
- const startL = performance.now();
811
- bst.lesserOrGreaterTraverse(
812
- node => {
813
- node.key - 1;
814
- },
815
- CP.lt,
816
- inputSize / 2
817
- );
818
- isDebug && console.log('---lesserOrGreaterTraverse', performance.now() - startL);
819
- });
820
-
821
- it('Should the time consumption of listLevels fitting well', function () {
822
- const nodes: number[] = [];
823
- for (let i = 0; i < inputSize; i++) {
824
- nodes.push(i);
825
- }
826
- const start = performance.now();
827
- bst.addMany(nodes);
828
- isDebug && console.log('---add', performance.now() - start);
829
- const startL = performance.now();
830
- const arr: number[][] = bst.listLevels(node => node.key);
831
- isDebug && console.log('---listLevels', arr);
832
- isDebug && console.log('---listLevels', performance.now() - startL);
833
- });
834
-
835
- it('should the lastKey of a BST to be the largest key', function () {
836
- const bst = new BST();
837
- bst.addMany([9, 8, 7, 3, 1, 2, 5, 4, 6], undefined, false);
838
- expect(bst.lastKey()).toBe(9);
839
- });
840
- });