data-structure-typed 1.43.1 → 1.44.0

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 (786) hide show
  1. package/.eslintrc.js +3 -1
  2. package/CHANGELOG.md +1 -1
  3. package/README.md +7 -0
  4. package/benchmark/report.html +30 -30
  5. package/benchmark/report.json +201 -147
  6. package/dist/cjs/data-structures/binary-tree/avl-tree.js.map +1 -0
  7. package/dist/cjs/data-structures/binary-tree/binary-indexed-tree.js.map +1 -0
  8. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/binary-tree.d.ts +8 -8
  9. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/binary-tree.js +62 -62
  10. package/dist/cjs/data-structures/binary-tree/binary-tree.js.map +1 -0
  11. package/dist/cjs/data-structures/binary-tree/bst.js.map +1 -0
  12. package/dist/cjs/data-structures/binary-tree/index.js.map +1 -0
  13. package/dist/{mjs/src → cjs}/data-structures/binary-tree/rb-tree.d.ts +4 -4
  14. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/rb-tree.js +1 -1
  15. package/dist/cjs/data-structures/binary-tree/rb-tree.js.map +1 -0
  16. package/dist/cjs/data-structures/binary-tree/segment-tree.js.map +1 -0
  17. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/tree-multimap.js +50 -50
  18. package/dist/cjs/data-structures/binary-tree/tree-multimap.js.map +1 -0
  19. package/dist/{mjs/src → cjs}/data-structures/graph/abstract-graph.d.ts +37 -37
  20. package/dist/cjs/{src/data-structures → data-structures}/graph/abstract-graph.js +37 -37
  21. package/dist/cjs/data-structures/graph/abstract-graph.js.map +1 -0
  22. package/dist/cjs/data-structures/graph/directed-graph.js.map +1 -0
  23. package/dist/cjs/data-structures/graph/index.js.map +1 -0
  24. package/dist/cjs/data-structures/graph/map-graph.js.map +1 -0
  25. package/dist/cjs/data-structures/graph/undirected-graph.js.map +1 -0
  26. package/dist/cjs/data-structures/hash/coordinate-map.js.map +1 -0
  27. package/dist/cjs/data-structures/hash/coordinate-set.js.map +1 -0
  28. package/dist/cjs/data-structures/hash/hash-map.js.map +1 -0
  29. package/dist/cjs/data-structures/hash/hash-table.js.map +1 -0
  30. package/dist/cjs/data-structures/hash/index.js.map +1 -0
  31. package/dist/cjs/data-structures/hash/tree-map.js.map +1 -0
  32. package/dist/cjs/data-structures/hash/tree-set.js.map +1 -0
  33. package/dist/cjs/data-structures/heap/heap.js.map +1 -0
  34. package/dist/cjs/data-structures/heap/index.js.map +1 -0
  35. package/dist/cjs/data-structures/heap/max-heap.js.map +1 -0
  36. package/dist/cjs/data-structures/heap/min-heap.js.map +1 -0
  37. package/dist/cjs/data-structures/index.js.map +1 -0
  38. package/dist/cjs/data-structures/linked-list/doubly-linked-list.js.map +1 -0
  39. package/dist/cjs/data-structures/linked-list/index.js.map +1 -0
  40. package/dist/cjs/data-structures/linked-list/singly-linked-list.js.map +1 -0
  41. package/dist/cjs/data-structures/linked-list/skip-linked-list.js.map +1 -0
  42. package/dist/cjs/data-structures/matrix/index.js.map +1 -0
  43. package/dist/cjs/data-structures/matrix/matrix.js.map +1 -0
  44. package/dist/cjs/data-structures/matrix/matrix2d.js.map +1 -0
  45. package/dist/cjs/data-structures/matrix/navigator.js.map +1 -0
  46. package/dist/cjs/data-structures/matrix/vector2d.js.map +1 -0
  47. package/dist/cjs/data-structures/priority-queue/index.js.map +1 -0
  48. package/dist/cjs/data-structures/priority-queue/max-priority-queue.js.map +1 -0
  49. package/dist/cjs/data-structures/priority-queue/min-priority-queue.js.map +1 -0
  50. package/dist/cjs/data-structures/priority-queue/priority-queue.js.map +1 -0
  51. package/dist/cjs/data-structures/queue/deque.js.map +1 -0
  52. package/dist/cjs/data-structures/queue/index.js.map +1 -0
  53. package/dist/cjs/data-structures/queue/queue.js.map +1 -0
  54. package/dist/cjs/data-structures/stack/index.js.map +1 -0
  55. package/dist/cjs/data-structures/stack/stack.js.map +1 -0
  56. package/dist/cjs/data-structures/tree/index.js.map +1 -0
  57. package/dist/cjs/data-structures/tree/tree.js.map +1 -0
  58. package/dist/cjs/data-structures/trie/index.js.map +1 -0
  59. package/dist/cjs/data-structures/trie/trie.js.map +1 -0
  60. package/dist/cjs/index.js.map +1 -0
  61. package/dist/cjs/{src/interfaces → interfaces}/binary-tree.d.ts +1 -1
  62. package/dist/cjs/interfaces/binary-tree.js.map +1 -0
  63. package/dist/cjs/interfaces/doubly-linked-list.js.map +1 -0
  64. package/dist/cjs/{src/interfaces → interfaces}/graph.js.map +1 -1
  65. package/dist/cjs/{src/interfaces → interfaces}/heap.js.map +1 -1
  66. package/dist/cjs/interfaces/index.js.map +1 -0
  67. package/dist/cjs/interfaces/navigator.js.map +1 -0
  68. package/dist/cjs/interfaces/priority-queue.js.map +1 -0
  69. package/dist/cjs/interfaces/segment-tree.js.map +1 -0
  70. package/dist/cjs/interfaces/singly-linked-list.js.map +1 -0
  71. package/dist/cjs/types/data-structures/binary-tree/avl-tree.js.map +1 -0
  72. package/dist/cjs/types/data-structures/binary-tree/binary-indexed-tree.js.map +1 -0
  73. package/dist/cjs/types/data-structures/binary-tree/binary-tree.js.map +1 -0
  74. package/dist/cjs/types/data-structures/binary-tree/bst.js.map +1 -0
  75. package/dist/cjs/types/data-structures/binary-tree/index.js.map +1 -0
  76. package/dist/cjs/types/data-structures/binary-tree/rb-tree.js.map +1 -0
  77. package/dist/cjs/types/data-structures/binary-tree/segment-tree.js.map +1 -0
  78. package/dist/cjs/types/data-structures/binary-tree/tree-multimap.js.map +1 -0
  79. package/dist/cjs/types/data-structures/graph/abstract-graph.js.map +1 -0
  80. package/dist/cjs/types/data-structures/graph/directed-graph.js.map +1 -0
  81. package/dist/cjs/types/data-structures/graph/index.js.map +1 -0
  82. package/dist/cjs/types/data-structures/graph/map-graph.js.map +1 -0
  83. package/dist/cjs/types/data-structures/graph/undirected-graph.js.map +1 -0
  84. package/dist/cjs/types/data-structures/hash/coordinate-map.js.map +1 -0
  85. package/dist/cjs/types/data-structures/hash/coordinate-set.js.map +1 -0
  86. package/dist/cjs/types/data-structures/hash/hash-map.js.map +1 -0
  87. package/dist/cjs/types/data-structures/hash/hash-table.js.map +1 -0
  88. package/dist/cjs/types/data-structures/hash/index.js.map +1 -0
  89. package/dist/cjs/types/data-structures/hash/tree-map.js.map +1 -0
  90. package/dist/cjs/types/data-structures/hash/tree-set.js.map +1 -0
  91. package/dist/cjs/types/data-structures/heap/heap.js.map +1 -0
  92. package/dist/cjs/types/data-structures/heap/index.js.map +1 -0
  93. package/dist/cjs/types/data-structures/heap/max-heap.js.map +1 -0
  94. package/dist/cjs/types/data-structures/heap/min-heap.js.map +1 -0
  95. package/dist/cjs/types/data-structures/index.js.map +1 -0
  96. package/dist/cjs/types/data-structures/linked-list/doubly-linked-list.js.map +1 -0
  97. package/dist/cjs/types/data-structures/linked-list/index.js.map +1 -0
  98. package/dist/cjs/types/data-structures/linked-list/singly-linked-list.js.map +1 -0
  99. package/dist/cjs/types/data-structures/linked-list/skip-linked-list.js.map +1 -0
  100. package/dist/cjs/types/data-structures/matrix/index.js.map +1 -0
  101. package/dist/cjs/types/data-structures/matrix/matrix.js.map +1 -0
  102. package/dist/cjs/types/data-structures/matrix/matrix2d.js.map +1 -0
  103. package/dist/cjs/types/data-structures/matrix/navigator.js.map +1 -0
  104. package/dist/cjs/types/data-structures/matrix/vector2d.js.map +1 -0
  105. package/dist/cjs/types/data-structures/priority-queue/index.js.map +1 -0
  106. package/dist/cjs/types/data-structures/priority-queue/max-priority-queue.js.map +1 -0
  107. package/dist/cjs/types/data-structures/priority-queue/min-priority-queue.js.map +1 -0
  108. package/dist/cjs/types/data-structures/priority-queue/priority-queue.js.map +1 -0
  109. package/dist/cjs/types/data-structures/queue/deque.js.map +1 -0
  110. package/dist/cjs/types/data-structures/queue/index.js.map +1 -0
  111. package/dist/cjs/types/data-structures/queue/queue.js.map +1 -0
  112. package/dist/cjs/types/data-structures/stack/index.js.map +1 -0
  113. package/dist/cjs/types/data-structures/stack/stack.js.map +1 -0
  114. package/dist/cjs/types/data-structures/tree/index.js.map +1 -0
  115. package/dist/cjs/types/data-structures/tree/tree.js.map +1 -0
  116. package/dist/cjs/types/data-structures/trie/index.js.map +1 -0
  117. package/dist/cjs/types/data-structures/trie/trie.js.map +1 -0
  118. package/dist/cjs/types/helpers.js.map +1 -0
  119. package/dist/cjs/types/index.js.map +1 -0
  120. package/dist/cjs/types/utils/index.js.map +1 -0
  121. package/dist/cjs/{src/types → types}/utils/utils.js.map +1 -1
  122. package/dist/cjs/types/utils/validate-type.js.map +1 -0
  123. package/dist/cjs/utils/index.js.map +1 -0
  124. package/dist/cjs/utils/utils.js.map +1 -0
  125. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/avl-tree.js +3 -8
  126. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/binary-indexed-tree.js +3 -7
  127. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/binary-tree.d.ts +8 -8
  128. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/binary-tree.js +97 -102
  129. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/bst.js +34 -39
  130. package/dist/mjs/data-structures/binary-tree/index.js +7 -0
  131. package/dist/{cjs/src → mjs}/data-structures/binary-tree/rb-tree.d.ts +4 -4
  132. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/rb-tree.js +43 -48
  133. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/segment-tree.js +2 -7
  134. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/tree-multimap.js +60 -65
  135. package/dist/{cjs/src → mjs}/data-structures/graph/abstract-graph.d.ts +37 -37
  136. package/dist/mjs/{src/data-structures → data-structures}/graph/abstract-graph.js +46 -52
  137. package/dist/mjs/{src/data-structures → data-structures}/graph/directed-graph.js +9 -15
  138. package/dist/mjs/data-structures/graph/index.js +4 -0
  139. package/dist/mjs/{src/data-structures → data-structures}/graph/map-graph.js +4 -10
  140. package/dist/mjs/{src/data-structures → data-structures}/graph/undirected-graph.js +7 -13
  141. package/dist/mjs/{src/data-structures → data-structures}/hash/coordinate-map.js +1 -5
  142. package/dist/mjs/{src/data-structures → data-structures}/hash/coordinate-set.js +1 -5
  143. package/dist/mjs/{src/data-structures → data-structures}/hash/hash-map.js +1 -5
  144. package/dist/mjs/{src/data-structures → data-structures}/hash/hash-table.js +2 -7
  145. package/dist/mjs/data-structures/hash/index.js +6 -0
  146. package/dist/mjs/data-structures/hash/tree-map.js +2 -0
  147. package/dist/mjs/data-structures/hash/tree-set.js +2 -0
  148. package/dist/mjs/{src/data-structures → data-structures}/heap/heap.js +3 -9
  149. package/dist/mjs/data-structures/heap/index.js +3 -0
  150. package/dist/mjs/{src/data-structures → data-structures}/heap/max-heap.js +2 -6
  151. package/dist/mjs/{src/data-structures → data-structures}/heap/min-heap.js +2 -6
  152. package/dist/mjs/data-structures/index.js +11 -0
  153. package/dist/mjs/{src/data-structures → data-structures}/linked-list/doubly-linked-list.js +2 -7
  154. package/dist/mjs/data-structures/linked-list/index.js +3 -0
  155. package/dist/mjs/{src/data-structures → data-structures}/linked-list/singly-linked-list.js +2 -7
  156. package/dist/mjs/{src/data-structures → data-structures}/linked-list/skip-linked-list.js +2 -7
  157. package/dist/mjs/data-structures/matrix/index.js +4 -0
  158. package/dist/mjs/{src/data-structures → data-structures}/matrix/matrix.js +1 -5
  159. package/dist/mjs/{src/data-structures → data-structures}/matrix/matrix2d.js +4 -8
  160. package/dist/mjs/{src/data-structures → data-structures}/matrix/navigator.js +2 -7
  161. package/dist/mjs/{src/data-structures → data-structures}/matrix/vector2d.js +1 -5
  162. package/dist/mjs/{src/data-structures → data-structures}/priority-queue/max-priority-queue.js +2 -6
  163. package/dist/mjs/{src/data-structures → data-structures}/priority-queue/min-priority-queue.js +2 -6
  164. package/dist/mjs/data-structures/priority-queue/priority-queue.js +13 -0
  165. package/dist/mjs/{src/data-structures → data-structures}/queue/deque.js +4 -10
  166. package/dist/mjs/{src/data-structures → data-structures}/queue/queue.js +3 -8
  167. package/dist/mjs/{src/data-structures → data-structures}/stack/stack.js +1 -5
  168. package/dist/mjs/{src/data-structures → data-structures}/tree/tree.js +1 -5
  169. package/dist/mjs/{src/data-structures → data-structures}/trie/trie.js +2 -7
  170. package/dist/mjs/index.js +4 -0
  171. package/dist/mjs/{src/interfaces → interfaces}/binary-tree.d.ts +1 -1
  172. package/dist/mjs/interfaces/index.js +8 -0
  173. package/dist/mjs/{src/types → types}/data-structures/binary-tree/binary-tree.js +4 -7
  174. package/dist/mjs/types/data-structures/binary-tree/index.js +6 -0
  175. package/dist/mjs/types/data-structures/binary-tree/rb-tree.js +5 -0
  176. package/dist/mjs/types/data-structures/graph/directed-graph.js +6 -0
  177. package/dist/mjs/types/data-structures/graph/index.js +3 -0
  178. package/dist/mjs/types/data-structures/hash/hash-table.js +1 -0
  179. package/dist/mjs/types/data-structures/hash/index.js +1 -0
  180. package/dist/mjs/types/data-structures/hash/tree-map.d.ts +1 -0
  181. package/dist/mjs/types/data-structures/hash/tree-map.js +1 -0
  182. package/dist/mjs/types/data-structures/hash/tree-set.d.ts +1 -0
  183. package/dist/mjs/types/data-structures/hash/tree-set.js +1 -0
  184. package/dist/mjs/types/data-structures/heap/heap.d.ts +1 -0
  185. package/dist/mjs/types/data-structures/heap/heap.js +1 -0
  186. package/dist/mjs/types/data-structures/heap/index.js +1 -0
  187. package/dist/mjs/types/data-structures/heap/max-heap.d.ts +1 -0
  188. package/dist/mjs/types/data-structures/heap/max-heap.js +1 -0
  189. package/dist/mjs/types/data-structures/heap/min-heap.d.ts +1 -0
  190. package/dist/mjs/types/data-structures/heap/min-heap.js +1 -0
  191. package/dist/mjs/types/data-structures/index.js +11 -0
  192. package/dist/mjs/types/data-structures/linked-list/doubly-linked-list.d.ts +1 -0
  193. package/dist/mjs/types/data-structures/linked-list/doubly-linked-list.js +1 -0
  194. package/dist/mjs/types/data-structures/linked-list/index.js +2 -0
  195. package/dist/mjs/types/data-structures/linked-list/singly-linked-list.d.ts +1 -0
  196. package/dist/mjs/types/data-structures/linked-list/singly-linked-list.js +1 -0
  197. package/dist/mjs/types/data-structures/linked-list/skip-linked-list.d.ts +1 -0
  198. package/dist/mjs/types/data-structures/linked-list/skip-linked-list.js +1 -0
  199. package/dist/mjs/types/data-structures/matrix/index.js +1 -0
  200. package/dist/mjs/types/data-structures/matrix/matrix.d.ts +1 -0
  201. package/dist/mjs/types/data-structures/matrix/matrix.js +1 -0
  202. package/dist/mjs/types/data-structures/matrix/matrix2d.d.ts +1 -0
  203. package/dist/mjs/types/data-structures/matrix/matrix2d.js +1 -0
  204. package/dist/mjs/types/data-structures/matrix/navigator.js +1 -0
  205. package/dist/mjs/types/data-structures/matrix/vector2d.d.ts +1 -0
  206. package/dist/mjs/types/data-structures/matrix/vector2d.js +1 -0
  207. package/dist/mjs/types/data-structures/priority-queue/index.d.ts +3 -0
  208. package/dist/mjs/types/data-structures/priority-queue/index.js +3 -0
  209. package/dist/mjs/types/data-structures/priority-queue/max-priority-queue.d.ts +1 -0
  210. package/dist/mjs/types/data-structures/priority-queue/max-priority-queue.js +1 -0
  211. package/dist/mjs/types/data-structures/priority-queue/min-priority-queue.d.ts +1 -0
  212. package/dist/mjs/types/data-structures/priority-queue/min-priority-queue.js +1 -0
  213. package/dist/mjs/types/data-structures/priority-queue/priority-queue.d.ts +1 -0
  214. package/dist/mjs/types/data-structures/priority-queue/priority-queue.js +1 -0
  215. package/dist/mjs/types/data-structures/queue/deque.d.ts +1 -0
  216. package/dist/mjs/types/data-structures/queue/deque.js +1 -0
  217. package/dist/mjs/types/data-structures/queue/index.d.ts +2 -0
  218. package/dist/mjs/types/data-structures/queue/index.js +2 -0
  219. package/dist/mjs/types/data-structures/queue/queue.d.ts +1 -0
  220. package/dist/mjs/types/data-structures/queue/queue.js +1 -0
  221. package/dist/mjs/types/data-structures/stack/index.d.ts +1 -0
  222. package/dist/mjs/types/data-structures/stack/index.js +1 -0
  223. package/dist/mjs/types/data-structures/stack/stack.d.ts +1 -0
  224. package/dist/mjs/types/data-structures/stack/stack.js +1 -0
  225. package/dist/mjs/types/data-structures/tree/index.d.ts +1 -0
  226. package/dist/mjs/types/data-structures/tree/index.js +1 -0
  227. package/dist/mjs/types/data-structures/tree/tree.d.ts +1 -0
  228. package/dist/mjs/types/data-structures/tree/tree.js +1 -0
  229. package/dist/mjs/types/data-structures/trie/index.d.ts +1 -0
  230. package/dist/mjs/types/data-structures/trie/index.js +1 -0
  231. package/dist/mjs/types/data-structures/trie/trie.d.ts +1 -0
  232. package/dist/mjs/types/data-structures/trie/trie.js +1 -0
  233. package/dist/mjs/types/helpers.js +6 -0
  234. package/dist/mjs/types/index.js +3 -0
  235. package/dist/mjs/types/utils/index.js +2 -0
  236. package/dist/mjs/types/utils/utils.js +1 -0
  237. package/dist/mjs/types/utils/validate-type.js +1 -0
  238. package/dist/mjs/utils/index.js +1 -0
  239. package/dist/mjs/utils/utils.js +54 -0
  240. package/dist/umd/data-structure-typed.js +10593 -0
  241. package/dist/umd/data-structure-typed.min.js +5 -10
  242. package/dist/umd/data-structure-typed.min.js.map +1 -1
  243. package/package.json +14 -15
  244. package/src/data-structures/binary-tree/avl-tree.ts +2 -3
  245. package/src/data-structures/binary-tree/binary-tree.ts +85 -92
  246. package/src/data-structures/binary-tree/bst.ts +14 -22
  247. package/src/data-structures/binary-tree/rb-tree.ts +11 -20
  248. package/src/data-structures/binary-tree/tree-multimap.ts +56 -58
  249. package/src/data-structures/graph/abstract-graph.ts +6 -22
  250. package/src/data-structures/graph/directed-graph.ts +3 -9
  251. package/src/data-structures/graph/map-graph.ts +6 -6
  252. package/src/data-structures/graph/undirected-graph.ts +1 -2
  253. package/src/data-structures/heap/heap.ts +1 -6
  254. package/src/data-structures/trie/trie.ts +1 -1
  255. package/src/interfaces/binary-tree.ts +1 -1
  256. package/src/types/utils/validate-type.ts +2 -16
  257. package/test/integration/index.html +50 -4
  258. package/test/performance/data-structures/binary-tree/rb-tree.test.ts +18 -19
  259. package/test/performance/data-structures/hash/hash-map.test.ts +10 -13
  260. package/test/performance/data-structures/linked-list/doubly-linked-list.test.ts +16 -16
  261. package/test/performance/data-structures/priority-queue/max-priority-queue.test.ts +1 -3
  262. package/test/performance/data-structures/priority-queue/priority-queue.test.ts +10 -12
  263. package/test/performance/data-structures/queue/deque.test.ts +18 -19
  264. package/test/performance/data-structures/queue/queue.test.ts +18 -19
  265. package/test/performance/data-structures/stack/stack.test.ts +10 -11
  266. package/test/performance/reportor.ts +4 -5
  267. package/test/unit/data-structures/binary-tree/avl-tree.test.ts +0 -1
  268. package/test/unit/data-structures/binary-tree/binary-tree.test.ts +83 -61
  269. package/test/unit/data-structures/binary-tree/bst.test.ts +2 -6
  270. package/test/unit/data-structures/binary-tree/rb-tree.test.ts +34 -25
  271. package/test/unit/data-structures/graph/abstract-graph.test.ts +6 -6
  272. package/test/unit/data-structures/graph/directed-graph.test.ts +8 -28
  273. package/test/unit/data-structures/heap/heap.test.ts +1 -8
  274. package/test/unit/data-structures/priority-queue/priority-queue.test.ts +34 -12
  275. package/test/utils/json2html.ts +2 -6
  276. package/tsconfig-base.json +0 -1
  277. package/tsconfig-cjs.json +4 -3
  278. package/tsconfig-mjs.json +5 -3
  279. package/tsup.config.js +39 -17
  280. package/dist/cjs/src/data-structures/binary-tree/avl-tree.js.map +0 -1
  281. package/dist/cjs/src/data-structures/binary-tree/binary-indexed-tree.js.map +0 -1
  282. package/dist/cjs/src/data-structures/binary-tree/binary-tree.js.map +0 -1
  283. package/dist/cjs/src/data-structures/binary-tree/bst.js.map +0 -1
  284. package/dist/cjs/src/data-structures/binary-tree/index.js.map +0 -1
  285. package/dist/cjs/src/data-structures/binary-tree/rb-tree.js.map +0 -1
  286. package/dist/cjs/src/data-structures/binary-tree/segment-tree.js.map +0 -1
  287. package/dist/cjs/src/data-structures/binary-tree/tree-multimap.js.map +0 -1
  288. package/dist/cjs/src/data-structures/graph/abstract-graph.js.map +0 -1
  289. package/dist/cjs/src/data-structures/graph/directed-graph.js.map +0 -1
  290. package/dist/cjs/src/data-structures/graph/index.js.map +0 -1
  291. package/dist/cjs/src/data-structures/graph/map-graph.js.map +0 -1
  292. package/dist/cjs/src/data-structures/graph/undirected-graph.js.map +0 -1
  293. package/dist/cjs/src/data-structures/hash/coordinate-map.js.map +0 -1
  294. package/dist/cjs/src/data-structures/hash/coordinate-set.js.map +0 -1
  295. package/dist/cjs/src/data-structures/hash/hash-map.js.map +0 -1
  296. package/dist/cjs/src/data-structures/hash/hash-table.js.map +0 -1
  297. package/dist/cjs/src/data-structures/hash/index.js.map +0 -1
  298. package/dist/cjs/src/data-structures/hash/tree-map.js.map +0 -1
  299. package/dist/cjs/src/data-structures/hash/tree-set.js.map +0 -1
  300. package/dist/cjs/src/data-structures/heap/heap.js.map +0 -1
  301. package/dist/cjs/src/data-structures/heap/index.js.map +0 -1
  302. package/dist/cjs/src/data-structures/heap/max-heap.js.map +0 -1
  303. package/dist/cjs/src/data-structures/heap/min-heap.js.map +0 -1
  304. package/dist/cjs/src/data-structures/index.js.map +0 -1
  305. package/dist/cjs/src/data-structures/linked-list/doubly-linked-list.js.map +0 -1
  306. package/dist/cjs/src/data-structures/linked-list/index.js.map +0 -1
  307. package/dist/cjs/src/data-structures/linked-list/singly-linked-list.js.map +0 -1
  308. package/dist/cjs/src/data-structures/linked-list/skip-linked-list.js.map +0 -1
  309. package/dist/cjs/src/data-structures/matrix/index.js.map +0 -1
  310. package/dist/cjs/src/data-structures/matrix/matrix.js.map +0 -1
  311. package/dist/cjs/src/data-structures/matrix/matrix2d.js.map +0 -1
  312. package/dist/cjs/src/data-structures/matrix/navigator.js.map +0 -1
  313. package/dist/cjs/src/data-structures/matrix/vector2d.js.map +0 -1
  314. package/dist/cjs/src/data-structures/priority-queue/index.js.map +0 -1
  315. package/dist/cjs/src/data-structures/priority-queue/max-priority-queue.js.map +0 -1
  316. package/dist/cjs/src/data-structures/priority-queue/min-priority-queue.js.map +0 -1
  317. package/dist/cjs/src/data-structures/priority-queue/priority-queue.js.map +0 -1
  318. package/dist/cjs/src/data-structures/queue/deque.js.map +0 -1
  319. package/dist/cjs/src/data-structures/queue/index.js.map +0 -1
  320. package/dist/cjs/src/data-structures/queue/queue.js.map +0 -1
  321. package/dist/cjs/src/data-structures/stack/index.js.map +0 -1
  322. package/dist/cjs/src/data-structures/stack/stack.js.map +0 -1
  323. package/dist/cjs/src/data-structures/tree/index.js.map +0 -1
  324. package/dist/cjs/src/data-structures/tree/tree.js.map +0 -1
  325. package/dist/cjs/src/data-structures/trie/index.js.map +0 -1
  326. package/dist/cjs/src/data-structures/trie/trie.js.map +0 -1
  327. package/dist/cjs/src/index.js.map +0 -1
  328. package/dist/cjs/src/interfaces/binary-tree.js.map +0 -1
  329. package/dist/cjs/src/interfaces/doubly-linked-list.js.map +0 -1
  330. package/dist/cjs/src/interfaces/index.js.map +0 -1
  331. package/dist/cjs/src/interfaces/navigator.js.map +0 -1
  332. package/dist/cjs/src/interfaces/priority-queue.js.map +0 -1
  333. package/dist/cjs/src/interfaces/segment-tree.js.map +0 -1
  334. package/dist/cjs/src/interfaces/singly-linked-list.js.map +0 -1
  335. package/dist/cjs/src/types/data-structures/binary-tree/avl-tree.js.map +0 -1
  336. package/dist/cjs/src/types/data-structures/binary-tree/binary-indexed-tree.js.map +0 -1
  337. package/dist/cjs/src/types/data-structures/binary-tree/binary-tree.js.map +0 -1
  338. package/dist/cjs/src/types/data-structures/binary-tree/bst.js.map +0 -1
  339. package/dist/cjs/src/types/data-structures/binary-tree/index.js.map +0 -1
  340. package/dist/cjs/src/types/data-structures/binary-tree/rb-tree.js.map +0 -1
  341. package/dist/cjs/src/types/data-structures/binary-tree/segment-tree.js.map +0 -1
  342. package/dist/cjs/src/types/data-structures/binary-tree/tree-multimap.js.map +0 -1
  343. package/dist/cjs/src/types/data-structures/graph/abstract-graph.js.map +0 -1
  344. package/dist/cjs/src/types/data-structures/graph/directed-graph.js.map +0 -1
  345. package/dist/cjs/src/types/data-structures/graph/index.js.map +0 -1
  346. package/dist/cjs/src/types/data-structures/graph/map-graph.js.map +0 -1
  347. package/dist/cjs/src/types/data-structures/graph/undirected-graph.js.map +0 -1
  348. package/dist/cjs/src/types/data-structures/hash/coordinate-map.js.map +0 -1
  349. package/dist/cjs/src/types/data-structures/hash/coordinate-set.js.map +0 -1
  350. package/dist/cjs/src/types/data-structures/hash/hash-map.js.map +0 -1
  351. package/dist/cjs/src/types/data-structures/hash/hash-table.js.map +0 -1
  352. package/dist/cjs/src/types/data-structures/hash/index.js.map +0 -1
  353. package/dist/cjs/src/types/data-structures/hash/tree-map.js.map +0 -1
  354. package/dist/cjs/src/types/data-structures/hash/tree-set.js.map +0 -1
  355. package/dist/cjs/src/types/data-structures/heap/heap.js.map +0 -1
  356. package/dist/cjs/src/types/data-structures/heap/index.js.map +0 -1
  357. package/dist/cjs/src/types/data-structures/heap/max-heap.js.map +0 -1
  358. package/dist/cjs/src/types/data-structures/heap/min-heap.js.map +0 -1
  359. package/dist/cjs/src/types/data-structures/index.js.map +0 -1
  360. package/dist/cjs/src/types/data-structures/linked-list/doubly-linked-list.js.map +0 -1
  361. package/dist/cjs/src/types/data-structures/linked-list/index.js.map +0 -1
  362. package/dist/cjs/src/types/data-structures/linked-list/singly-linked-list.js.map +0 -1
  363. package/dist/cjs/src/types/data-structures/linked-list/skip-linked-list.js.map +0 -1
  364. package/dist/cjs/src/types/data-structures/matrix/index.js.map +0 -1
  365. package/dist/cjs/src/types/data-structures/matrix/matrix.js.map +0 -1
  366. package/dist/cjs/src/types/data-structures/matrix/matrix2d.js.map +0 -1
  367. package/dist/cjs/src/types/data-structures/matrix/navigator.js.map +0 -1
  368. package/dist/cjs/src/types/data-structures/matrix/vector2d.js.map +0 -1
  369. package/dist/cjs/src/types/data-structures/priority-queue/index.js.map +0 -1
  370. package/dist/cjs/src/types/data-structures/priority-queue/max-priority-queue.js.map +0 -1
  371. package/dist/cjs/src/types/data-structures/priority-queue/min-priority-queue.js.map +0 -1
  372. package/dist/cjs/src/types/data-structures/priority-queue/priority-queue.js.map +0 -1
  373. package/dist/cjs/src/types/data-structures/queue/deque.js.map +0 -1
  374. package/dist/cjs/src/types/data-structures/queue/index.js.map +0 -1
  375. package/dist/cjs/src/types/data-structures/queue/queue.js.map +0 -1
  376. package/dist/cjs/src/types/data-structures/stack/index.js.map +0 -1
  377. package/dist/cjs/src/types/data-structures/stack/stack.js.map +0 -1
  378. package/dist/cjs/src/types/data-structures/tree/index.js.map +0 -1
  379. package/dist/cjs/src/types/data-structures/tree/tree.js.map +0 -1
  380. package/dist/cjs/src/types/data-structures/trie/index.js.map +0 -1
  381. package/dist/cjs/src/types/data-structures/trie/trie.js.map +0 -1
  382. package/dist/cjs/src/types/helpers.js.map +0 -1
  383. package/dist/cjs/src/types/index.js.map +0 -1
  384. package/dist/cjs/src/types/utils/index.js.map +0 -1
  385. package/dist/cjs/src/types/utils/validate-type.js.map +0 -1
  386. package/dist/cjs/src/utils/index.js.map +0 -1
  387. package/dist/cjs/src/utils/utils.js.map +0 -1
  388. package/dist/mjs/src/data-structures/binary-tree/index.js +0 -23
  389. package/dist/mjs/src/data-structures/graph/index.js +0 -20
  390. package/dist/mjs/src/data-structures/hash/index.js +0 -22
  391. package/dist/mjs/src/data-structures/hash/tree-map.js +0 -6
  392. package/dist/mjs/src/data-structures/hash/tree-set.js +0 -6
  393. package/dist/mjs/src/data-structures/heap/index.js +0 -19
  394. package/dist/mjs/src/data-structures/index.js +0 -27
  395. package/dist/mjs/src/data-structures/linked-list/index.js +0 -19
  396. package/dist/mjs/src/data-structures/matrix/index.js +0 -20
  397. package/dist/mjs/src/data-structures/priority-queue/index.js +0 -19
  398. package/dist/mjs/src/data-structures/priority-queue/priority-queue.js +0 -17
  399. package/dist/mjs/src/data-structures/queue/index.js +0 -18
  400. package/dist/mjs/src/data-structures/stack/index.js +0 -17
  401. package/dist/mjs/src/data-structures/tree/index.js +0 -17
  402. package/dist/mjs/src/data-structures/trie/index.js +0 -17
  403. package/dist/mjs/src/index.js +0 -20
  404. package/dist/mjs/src/interfaces/binary-tree.js +0 -2
  405. package/dist/mjs/src/interfaces/doubly-linked-list.js +0 -2
  406. package/dist/mjs/src/interfaces/graph.js +0 -2
  407. package/dist/mjs/src/interfaces/heap.js +0 -2
  408. package/dist/mjs/src/interfaces/index.js +0 -24
  409. package/dist/mjs/src/interfaces/navigator.js +0 -2
  410. package/dist/mjs/src/interfaces/priority-queue.js +0 -2
  411. package/dist/mjs/src/interfaces/segment-tree.js +0 -2
  412. package/dist/mjs/src/interfaces/singly-linked-list.js +0 -2
  413. package/dist/mjs/src/types/data-structures/binary-tree/avl-tree.js +0 -2
  414. package/dist/mjs/src/types/data-structures/binary-tree/binary-indexed-tree.js +0 -2
  415. package/dist/mjs/src/types/data-structures/binary-tree/bst.js +0 -2
  416. package/dist/mjs/src/types/data-structures/binary-tree/index.js +0 -22
  417. package/dist/mjs/src/types/data-structures/binary-tree/rb-tree.js +0 -8
  418. package/dist/mjs/src/types/data-structures/binary-tree/segment-tree.js +0 -2
  419. package/dist/mjs/src/types/data-structures/binary-tree/tree-multimap.js +0 -2
  420. package/dist/mjs/src/types/data-structures/graph/abstract-graph.js +0 -2
  421. package/dist/mjs/src/types/data-structures/graph/directed-graph.js +0 -9
  422. package/dist/mjs/src/types/data-structures/graph/index.js +0 -19
  423. package/dist/mjs/src/types/data-structures/graph/map-graph.js +0 -2
  424. package/dist/mjs/src/types/data-structures/graph/undirected-graph.js +0 -2
  425. package/dist/mjs/src/types/data-structures/hash/coordinate-map.js +0 -2
  426. package/dist/mjs/src/types/data-structures/hash/coordinate-set.js +0 -2
  427. package/dist/mjs/src/types/data-structures/hash/hash-map.js +0 -2
  428. package/dist/mjs/src/types/data-structures/hash/hash-table.js +0 -2
  429. package/dist/mjs/src/types/data-structures/hash/index.js +0 -2
  430. package/dist/mjs/src/types/data-structures/hash/tree-map.js +0 -2
  431. package/dist/mjs/src/types/data-structures/hash/tree-set.js +0 -2
  432. package/dist/mjs/src/types/data-structures/heap/heap.js +0 -2
  433. package/dist/mjs/src/types/data-structures/heap/index.js +0 -17
  434. package/dist/mjs/src/types/data-structures/heap/max-heap.js +0 -2
  435. package/dist/mjs/src/types/data-structures/heap/min-heap.js +0 -2
  436. package/dist/mjs/src/types/data-structures/index.js +0 -27
  437. package/dist/mjs/src/types/data-structures/linked-list/doubly-linked-list.js +0 -2
  438. package/dist/mjs/src/types/data-structures/linked-list/index.js +0 -18
  439. package/dist/mjs/src/types/data-structures/linked-list/singly-linked-list.js +0 -2
  440. package/dist/mjs/src/types/data-structures/linked-list/skip-linked-list.js +0 -2
  441. package/dist/mjs/src/types/data-structures/matrix/index.js +0 -17
  442. package/dist/mjs/src/types/data-structures/matrix/matrix.js +0 -2
  443. package/dist/mjs/src/types/data-structures/matrix/matrix2d.js +0 -2
  444. package/dist/mjs/src/types/data-structures/matrix/navigator.js +0 -2
  445. package/dist/mjs/src/types/data-structures/matrix/vector2d.js +0 -2
  446. package/dist/mjs/src/types/data-structures/priority-queue/index.js +0 -19
  447. package/dist/mjs/src/types/data-structures/priority-queue/max-priority-queue.js +0 -2
  448. package/dist/mjs/src/types/data-structures/priority-queue/min-priority-queue.js +0 -2
  449. package/dist/mjs/src/types/data-structures/priority-queue/priority-queue.js +0 -2
  450. package/dist/mjs/src/types/data-structures/queue/deque.js +0 -2
  451. package/dist/mjs/src/types/data-structures/queue/index.js +0 -18
  452. package/dist/mjs/src/types/data-structures/queue/queue.js +0 -2
  453. package/dist/mjs/src/types/data-structures/stack/index.js +0 -17
  454. package/dist/mjs/src/types/data-structures/stack/stack.js +0 -2
  455. package/dist/mjs/src/types/data-structures/tree/index.js +0 -17
  456. package/dist/mjs/src/types/data-structures/tree/tree.js +0 -2
  457. package/dist/mjs/src/types/data-structures/trie/index.js +0 -17
  458. package/dist/mjs/src/types/data-structures/trie/trie.js +0 -2
  459. package/dist/mjs/src/types/helpers.js +0 -9
  460. package/dist/mjs/src/types/index.js +0 -19
  461. package/dist/mjs/src/types/utils/index.js +0 -18
  462. package/dist/mjs/src/types/utils/utils.js +0 -2
  463. package/dist/mjs/src/types/utils/validate-type.js +0 -2
  464. package/dist/mjs/src/utils/index.js +0 -17
  465. package/dist/mjs/src/utils/utils.js +0 -64
  466. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/avl-tree.d.ts +0 -0
  467. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/avl-tree.js +0 -0
  468. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/binary-indexed-tree.d.ts +0 -0
  469. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/binary-indexed-tree.js +0 -0
  470. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/bst.d.ts +0 -0
  471. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/bst.js +0 -0
  472. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/index.d.ts +0 -0
  473. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/index.js +0 -0
  474. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/segment-tree.d.ts +0 -0
  475. package/dist/cjs/{src/data-structures → data-structures}/binary-tree/segment-tree.js +0 -0
  476. package/dist/{mjs/src → cjs}/data-structures/binary-tree/tree-multimap.d.ts +24 -24
  477. package/dist/cjs/{src/data-structures → data-structures}/graph/directed-graph.d.ts +0 -0
  478. package/dist/cjs/{src/data-structures → data-structures}/graph/directed-graph.js +0 -0
  479. package/dist/cjs/{src/data-structures → data-structures}/graph/index.d.ts +0 -0
  480. package/dist/cjs/{src/data-structures → data-structures}/graph/index.js +0 -0
  481. package/dist/cjs/{src/data-structures → data-structures}/graph/map-graph.d.ts +0 -0
  482. package/dist/cjs/{src/data-structures → data-structures}/graph/map-graph.js +0 -0
  483. package/dist/cjs/{src/data-structures → data-structures}/graph/undirected-graph.d.ts +0 -0
  484. package/dist/cjs/{src/data-structures → data-structures}/graph/undirected-graph.js +0 -0
  485. package/dist/cjs/{src/data-structures → data-structures}/hash/coordinate-map.d.ts +0 -0
  486. package/dist/cjs/{src/data-structures → data-structures}/hash/coordinate-map.js +0 -0
  487. package/dist/cjs/{src/data-structures → data-structures}/hash/coordinate-set.d.ts +0 -0
  488. package/dist/cjs/{src/data-structures → data-structures}/hash/coordinate-set.js +0 -0
  489. package/dist/cjs/{src/data-structures → data-structures}/hash/hash-map.d.ts +0 -0
  490. package/dist/cjs/{src/data-structures → data-structures}/hash/hash-map.js +0 -0
  491. package/dist/cjs/{src/data-structures → data-structures}/hash/hash-table.d.ts +0 -0
  492. package/dist/cjs/{src/data-structures → data-structures}/hash/hash-table.js +0 -0
  493. package/dist/cjs/{src/data-structures → data-structures}/hash/index.d.ts +0 -0
  494. package/dist/cjs/{src/data-structures → data-structures}/hash/index.js +0 -0
  495. package/dist/cjs/{src/data-structures → data-structures}/hash/tree-map.d.ts +0 -0
  496. package/dist/cjs/{src/data-structures → data-structures}/hash/tree-map.js +0 -0
  497. package/dist/cjs/{src/data-structures → data-structures}/hash/tree-set.d.ts +0 -0
  498. package/dist/cjs/{src/data-structures → data-structures}/hash/tree-set.js +0 -0
  499. package/dist/cjs/{src/data-structures → data-structures}/heap/heap.d.ts +0 -0
  500. package/dist/cjs/{src/data-structures → data-structures}/heap/heap.js +0 -0
  501. package/dist/cjs/{src/data-structures → data-structures}/heap/index.d.ts +0 -0
  502. package/dist/cjs/{src/data-structures → data-structures}/heap/index.js +0 -0
  503. package/dist/cjs/{src/data-structures → data-structures}/heap/max-heap.d.ts +0 -0
  504. package/dist/cjs/{src/data-structures → data-structures}/heap/max-heap.js +0 -0
  505. package/dist/cjs/{src/data-structures → data-structures}/heap/min-heap.d.ts +0 -0
  506. package/dist/cjs/{src/data-structures → data-structures}/heap/min-heap.js +0 -0
  507. package/dist/cjs/{src/data-structures → data-structures}/index.d.ts +0 -0
  508. package/dist/cjs/{src/data-structures → data-structures}/index.js +0 -0
  509. package/dist/cjs/{src/data-structures → data-structures}/linked-list/doubly-linked-list.d.ts +0 -0
  510. package/dist/cjs/{src/data-structures → data-structures}/linked-list/doubly-linked-list.js +0 -0
  511. package/dist/cjs/{src/data-structures → data-structures}/linked-list/index.d.ts +0 -0
  512. package/dist/cjs/{src/data-structures → data-structures}/linked-list/index.js +0 -0
  513. package/dist/cjs/{src/data-structures → data-structures}/linked-list/singly-linked-list.d.ts +0 -0
  514. package/dist/cjs/{src/data-structures → data-structures}/linked-list/singly-linked-list.js +0 -0
  515. package/dist/cjs/{src/data-structures → data-structures}/linked-list/skip-linked-list.d.ts +0 -0
  516. package/dist/cjs/{src/data-structures → data-structures}/linked-list/skip-linked-list.js +0 -0
  517. package/dist/cjs/{src/data-structures → data-structures}/matrix/index.d.ts +0 -0
  518. package/dist/cjs/{src/data-structures → data-structures}/matrix/index.js +0 -0
  519. package/dist/cjs/{src/data-structures → data-structures}/matrix/matrix.d.ts +0 -0
  520. package/dist/cjs/{src/data-structures → data-structures}/matrix/matrix.js +0 -0
  521. package/dist/cjs/{src/data-structures → data-structures}/matrix/matrix2d.d.ts +0 -0
  522. package/dist/cjs/{src/data-structures → data-structures}/matrix/matrix2d.js +0 -0
  523. package/dist/cjs/{src/data-structures → data-structures}/matrix/navigator.d.ts +0 -0
  524. package/dist/cjs/{src/data-structures → data-structures}/matrix/navigator.js +0 -0
  525. package/dist/cjs/{src/data-structures → data-structures}/matrix/vector2d.d.ts +0 -0
  526. package/dist/cjs/{src/data-structures → data-structures}/matrix/vector2d.js +0 -0
  527. package/dist/cjs/{src/data-structures → data-structures}/priority-queue/index.d.ts +0 -0
  528. package/dist/cjs/{src/data-structures → data-structures}/priority-queue/index.js +0 -0
  529. package/dist/cjs/{src/data-structures → data-structures}/priority-queue/max-priority-queue.d.ts +0 -0
  530. package/dist/cjs/{src/data-structures → data-structures}/priority-queue/max-priority-queue.js +0 -0
  531. package/dist/cjs/{src/data-structures → data-structures}/priority-queue/min-priority-queue.d.ts +0 -0
  532. package/dist/cjs/{src/data-structures → data-structures}/priority-queue/min-priority-queue.js +0 -0
  533. package/dist/cjs/{src/data-structures → data-structures}/priority-queue/priority-queue.d.ts +0 -0
  534. package/dist/cjs/{src/data-structures → data-structures}/priority-queue/priority-queue.js +0 -0
  535. package/dist/cjs/{src/data-structures → data-structures}/queue/deque.d.ts +0 -0
  536. package/dist/cjs/{src/data-structures → data-structures}/queue/deque.js +0 -0
  537. package/dist/cjs/{src/data-structures → data-structures}/queue/index.d.ts +0 -0
  538. package/dist/cjs/{src/data-structures → data-structures}/queue/index.js +0 -0
  539. package/dist/cjs/{src/data-structures → data-structures}/queue/queue.d.ts +0 -0
  540. package/dist/cjs/{src/data-structures → data-structures}/queue/queue.js +0 -0
  541. package/dist/cjs/{src/data-structures → data-structures}/stack/index.d.ts +0 -0
  542. package/dist/cjs/{src/data-structures → data-structures}/stack/index.js +0 -0
  543. package/dist/cjs/{src/data-structures → data-structures}/stack/stack.d.ts +0 -0
  544. package/dist/cjs/{src/data-structures → data-structures}/stack/stack.js +0 -0
  545. package/dist/cjs/{src/data-structures → data-structures}/tree/index.d.ts +0 -0
  546. package/dist/cjs/{src/data-structures → data-structures}/tree/index.js +0 -0
  547. package/dist/cjs/{src/data-structures → data-structures}/tree/tree.d.ts +0 -0
  548. package/dist/cjs/{src/data-structures → data-structures}/tree/tree.js +0 -0
  549. package/dist/cjs/{src/data-structures → data-structures}/trie/index.d.ts +0 -0
  550. package/dist/cjs/{src/data-structures → data-structures}/trie/index.js +0 -0
  551. package/dist/cjs/{src/data-structures → data-structures}/trie/trie.d.ts +0 -0
  552. package/dist/cjs/{src/data-structures → data-structures}/trie/trie.js +0 -0
  553. package/dist/cjs/{src/index.d.ts → index.d.ts} +0 -0
  554. package/dist/cjs/{src/index.js → index.js} +0 -0
  555. package/dist/cjs/{src/interfaces → interfaces}/binary-tree.js +0 -0
  556. package/dist/cjs/{src/interfaces → interfaces}/doubly-linked-list.d.ts +0 -0
  557. package/dist/cjs/{src/interfaces → interfaces}/doubly-linked-list.js +0 -0
  558. package/dist/cjs/{src/interfaces → interfaces}/graph.d.ts +0 -0
  559. package/dist/cjs/{src/interfaces → interfaces}/graph.js +0 -0
  560. package/dist/cjs/{src/interfaces → interfaces}/heap.d.ts +0 -0
  561. package/dist/cjs/{src/interfaces → interfaces}/heap.js +0 -0
  562. package/dist/cjs/{src/interfaces → interfaces}/index.d.ts +0 -0
  563. package/dist/cjs/{src/interfaces → interfaces}/index.js +0 -0
  564. package/dist/cjs/{src/interfaces → interfaces}/navigator.d.ts +0 -0
  565. package/dist/cjs/{src/interfaces → interfaces}/navigator.js +0 -0
  566. package/dist/cjs/{src/interfaces → interfaces}/priority-queue.d.ts +0 -0
  567. package/dist/cjs/{src/interfaces → interfaces}/priority-queue.js +0 -0
  568. package/dist/cjs/{src/interfaces → interfaces}/segment-tree.d.ts +0 -0
  569. package/dist/cjs/{src/interfaces → interfaces}/segment-tree.js +0 -0
  570. package/dist/cjs/{src/interfaces → interfaces}/singly-linked-list.d.ts +0 -0
  571. package/dist/cjs/{src/interfaces → interfaces}/singly-linked-list.js +0 -0
  572. package/dist/cjs/{src/types → types}/data-structures/binary-tree/avl-tree.d.ts +0 -0
  573. package/dist/cjs/{src/types → types}/data-structures/binary-tree/avl-tree.js +0 -0
  574. package/dist/cjs/{src/types → types}/data-structures/binary-tree/binary-indexed-tree.d.ts +0 -0
  575. package/dist/cjs/{src/types → types}/data-structures/binary-tree/binary-indexed-tree.js +0 -0
  576. package/dist/cjs/{src/types → types}/data-structures/binary-tree/binary-tree.d.ts +0 -0
  577. package/dist/cjs/{src/types → types}/data-structures/binary-tree/binary-tree.js +0 -0
  578. package/dist/cjs/{src/types → types}/data-structures/binary-tree/bst.d.ts +0 -0
  579. package/dist/cjs/{src/types → types}/data-structures/binary-tree/bst.js +0 -0
  580. package/dist/cjs/{src/types → types}/data-structures/binary-tree/index.d.ts +0 -0
  581. package/dist/cjs/{src/types → types}/data-structures/binary-tree/index.js +0 -0
  582. package/dist/cjs/{src/types → types}/data-structures/binary-tree/rb-tree.d.ts +0 -0
  583. package/dist/cjs/{src/types → types}/data-structures/binary-tree/rb-tree.js +0 -0
  584. package/dist/cjs/{src/types → types}/data-structures/binary-tree/segment-tree.d.ts +0 -0
  585. package/dist/cjs/{src/types → types}/data-structures/binary-tree/segment-tree.js +0 -0
  586. package/dist/cjs/{src/types → types}/data-structures/binary-tree/tree-multimap.d.ts +0 -0
  587. package/dist/cjs/{src/types → types}/data-structures/binary-tree/tree-multimap.js +0 -0
  588. package/dist/cjs/{src/types → types}/data-structures/graph/abstract-graph.d.ts +0 -0
  589. package/dist/cjs/{src/types → types}/data-structures/graph/abstract-graph.js +0 -0
  590. package/dist/cjs/{src/types → types}/data-structures/graph/directed-graph.d.ts +0 -0
  591. package/dist/cjs/{src/types → types}/data-structures/graph/directed-graph.js +0 -0
  592. package/dist/cjs/{src/types → types}/data-structures/graph/index.d.ts +0 -0
  593. package/dist/cjs/{src/types → types}/data-structures/graph/index.js +0 -0
  594. package/dist/cjs/{src/types → types}/data-structures/graph/map-graph.d.ts +0 -0
  595. package/dist/cjs/{src/types → types}/data-structures/graph/map-graph.js +0 -0
  596. package/dist/cjs/{src/types → types}/data-structures/graph/undirected-graph.d.ts +0 -0
  597. package/dist/cjs/{src/types → types}/data-structures/graph/undirected-graph.js +0 -0
  598. package/dist/cjs/{src/types → types}/data-structures/hash/coordinate-map.d.ts +0 -0
  599. package/dist/cjs/{src/types → types}/data-structures/hash/coordinate-map.js +0 -0
  600. package/dist/cjs/{src/types → types}/data-structures/hash/coordinate-set.d.ts +0 -0
  601. package/dist/cjs/{src/types → types}/data-structures/hash/coordinate-set.js +0 -0
  602. package/dist/cjs/{src/types → types}/data-structures/hash/hash-map.d.ts +0 -0
  603. package/dist/cjs/{src/types → types}/data-structures/hash/hash-map.js +0 -0
  604. package/dist/cjs/{src/types → types}/data-structures/hash/hash-table.d.ts +0 -0
  605. package/dist/cjs/{src/types → types}/data-structures/hash/hash-table.js +0 -0
  606. package/dist/cjs/{src/types → types}/data-structures/hash/index.d.ts +0 -0
  607. package/dist/cjs/{src/types → types}/data-structures/hash/index.js +0 -0
  608. package/dist/cjs/{src/types → types}/data-structures/hash/tree-map.d.ts +0 -0
  609. package/dist/cjs/{src/types → types}/data-structures/hash/tree-map.js +0 -0
  610. package/dist/cjs/{src/types → types}/data-structures/hash/tree-set.d.ts +0 -0
  611. package/dist/cjs/{src/types → types}/data-structures/hash/tree-set.js +0 -0
  612. package/dist/cjs/{src/types → types}/data-structures/heap/heap.d.ts +0 -0
  613. package/dist/cjs/{src/types → types}/data-structures/heap/heap.js +0 -0
  614. package/dist/cjs/{src/types → types}/data-structures/heap/index.d.ts +0 -0
  615. package/dist/cjs/{src/types → types}/data-structures/heap/index.js +0 -0
  616. package/dist/cjs/{src/types → types}/data-structures/heap/max-heap.d.ts +0 -0
  617. package/dist/cjs/{src/types → types}/data-structures/heap/max-heap.js +0 -0
  618. package/dist/cjs/{src/types → types}/data-structures/heap/min-heap.d.ts +0 -0
  619. package/dist/cjs/{src/types → types}/data-structures/heap/min-heap.js +0 -0
  620. package/dist/cjs/{src/types → types}/data-structures/index.d.ts +0 -0
  621. package/dist/cjs/{src/types → types}/data-structures/index.js +0 -0
  622. package/dist/cjs/{src/types → types}/data-structures/linked-list/doubly-linked-list.d.ts +0 -0
  623. package/dist/cjs/{src/types → types}/data-structures/linked-list/doubly-linked-list.js +0 -0
  624. package/dist/cjs/{src/types → types}/data-structures/linked-list/index.d.ts +0 -0
  625. package/dist/cjs/{src/types → types}/data-structures/linked-list/index.js +0 -0
  626. package/dist/cjs/{src/types → types}/data-structures/linked-list/singly-linked-list.d.ts +0 -0
  627. package/dist/cjs/{src/types → types}/data-structures/linked-list/singly-linked-list.js +0 -0
  628. package/dist/cjs/{src/types → types}/data-structures/linked-list/skip-linked-list.d.ts +0 -0
  629. package/dist/cjs/{src/types → types}/data-structures/linked-list/skip-linked-list.js +0 -0
  630. package/dist/cjs/{src/types → types}/data-structures/matrix/index.d.ts +0 -0
  631. package/dist/cjs/{src/types → types}/data-structures/matrix/index.js +0 -0
  632. package/dist/cjs/{src/types → types}/data-structures/matrix/matrix.d.ts +0 -0
  633. package/dist/cjs/{src/types → types}/data-structures/matrix/matrix.js +0 -0
  634. package/dist/cjs/{src/types → types}/data-structures/matrix/matrix2d.d.ts +0 -0
  635. package/dist/cjs/{src/types → types}/data-structures/matrix/matrix2d.js +0 -0
  636. package/dist/cjs/{src/types → types}/data-structures/matrix/navigator.d.ts +0 -0
  637. package/dist/cjs/{src/types → types}/data-structures/matrix/navigator.js +0 -0
  638. package/dist/cjs/{src/types → types}/data-structures/matrix/vector2d.d.ts +0 -0
  639. package/dist/cjs/{src/types → types}/data-structures/matrix/vector2d.js +0 -0
  640. package/dist/cjs/{src/types → types}/data-structures/priority-queue/index.d.ts +0 -0
  641. package/dist/cjs/{src/types → types}/data-structures/priority-queue/index.js +0 -0
  642. package/dist/cjs/{src/types → types}/data-structures/priority-queue/max-priority-queue.d.ts +0 -0
  643. package/dist/cjs/{src/types → types}/data-structures/priority-queue/max-priority-queue.js +0 -0
  644. package/dist/cjs/{src/types → types}/data-structures/priority-queue/min-priority-queue.d.ts +0 -0
  645. package/dist/cjs/{src/types → types}/data-structures/priority-queue/min-priority-queue.js +0 -0
  646. package/dist/cjs/{src/types → types}/data-structures/priority-queue/priority-queue.d.ts +0 -0
  647. package/dist/cjs/{src/types → types}/data-structures/priority-queue/priority-queue.js +0 -0
  648. package/dist/cjs/{src/types → types}/data-structures/queue/deque.d.ts +0 -0
  649. package/dist/cjs/{src/types → types}/data-structures/queue/deque.js +0 -0
  650. package/dist/cjs/{src/types → types}/data-structures/queue/index.d.ts +0 -0
  651. package/dist/cjs/{src/types → types}/data-structures/queue/index.js +0 -0
  652. package/dist/cjs/{src/types → types}/data-structures/queue/queue.d.ts +0 -0
  653. package/dist/cjs/{src/types → types}/data-structures/queue/queue.js +0 -0
  654. package/dist/cjs/{src/types → types}/data-structures/stack/index.d.ts +0 -0
  655. package/dist/cjs/{src/types → types}/data-structures/stack/index.js +0 -0
  656. package/dist/cjs/{src/types → types}/data-structures/stack/stack.d.ts +0 -0
  657. package/dist/cjs/{src/types → types}/data-structures/stack/stack.js +0 -0
  658. package/dist/cjs/{src/types → types}/data-structures/tree/index.d.ts +0 -0
  659. package/dist/cjs/{src/types → types}/data-structures/tree/index.js +0 -0
  660. package/dist/cjs/{src/types → types}/data-structures/tree/tree.d.ts +0 -0
  661. package/dist/cjs/{src/types → types}/data-structures/tree/tree.js +0 -0
  662. package/dist/cjs/{src/types → types}/data-structures/trie/index.d.ts +0 -0
  663. package/dist/cjs/{src/types → types}/data-structures/trie/index.js +0 -0
  664. package/dist/cjs/{src/types → types}/data-structures/trie/trie.d.ts +0 -0
  665. package/dist/cjs/{src/types → types}/data-structures/trie/trie.js +0 -0
  666. package/dist/cjs/{src/types → types}/helpers.d.ts +0 -0
  667. package/dist/cjs/{src/types → types}/helpers.js +0 -0
  668. package/dist/cjs/{src/types → types}/index.d.ts +0 -0
  669. package/dist/cjs/{src/types → types}/index.js +0 -0
  670. package/dist/cjs/{src/types → types}/utils/index.d.ts +0 -0
  671. package/dist/cjs/{src/types → types}/utils/index.js +0 -0
  672. package/dist/cjs/{src/types → types}/utils/utils.d.ts +0 -0
  673. package/dist/cjs/{src/types → types}/utils/utils.js +0 -0
  674. package/dist/cjs/{src/types → types}/utils/validate-type.d.ts +0 -0
  675. package/dist/cjs/{src/types → types}/utils/validate-type.js +0 -0
  676. package/dist/cjs/{src/utils → utils}/index.d.ts +0 -0
  677. package/dist/cjs/{src/utils → utils}/index.js +0 -0
  678. package/dist/cjs/{src/utils → utils}/utils.d.ts +0 -0
  679. package/dist/cjs/{src/utils → utils}/utils.js +0 -0
  680. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/avl-tree.d.ts +0 -0
  681. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/binary-indexed-tree.d.ts +0 -0
  682. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/bst.d.ts +0 -0
  683. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/index.d.ts +0 -0
  684. package/dist/mjs/{src/data-structures → data-structures}/binary-tree/segment-tree.d.ts +0 -0
  685. package/dist/{cjs/src → mjs}/data-structures/binary-tree/tree-multimap.d.ts +24 -24
  686. /package/dist/mjs/{src/data-structures → data-structures}/graph/directed-graph.d.ts +0 -0
  687. /package/dist/mjs/{src/data-structures → data-structures}/graph/index.d.ts +0 -0
  688. /package/dist/mjs/{src/data-structures → data-structures}/graph/map-graph.d.ts +0 -0
  689. /package/dist/mjs/{src/data-structures → data-structures}/graph/undirected-graph.d.ts +0 -0
  690. /package/dist/mjs/{src/data-structures → data-structures}/hash/coordinate-map.d.ts +0 -0
  691. /package/dist/mjs/{src/data-structures → data-structures}/hash/coordinate-set.d.ts +0 -0
  692. /package/dist/mjs/{src/data-structures → data-structures}/hash/hash-map.d.ts +0 -0
  693. /package/dist/mjs/{src/data-structures → data-structures}/hash/hash-table.d.ts +0 -0
  694. /package/dist/mjs/{src/data-structures → data-structures}/hash/index.d.ts +0 -0
  695. /package/dist/mjs/{src/data-structures → data-structures}/hash/tree-map.d.ts +0 -0
  696. /package/dist/mjs/{src/data-structures → data-structures}/hash/tree-set.d.ts +0 -0
  697. /package/dist/mjs/{src/data-structures → data-structures}/heap/heap.d.ts +0 -0
  698. /package/dist/mjs/{src/data-structures → data-structures}/heap/index.d.ts +0 -0
  699. /package/dist/mjs/{src/data-structures → data-structures}/heap/max-heap.d.ts +0 -0
  700. /package/dist/mjs/{src/data-structures → data-structures}/heap/min-heap.d.ts +0 -0
  701. /package/dist/mjs/{src/data-structures → data-structures}/index.d.ts +0 -0
  702. /package/dist/mjs/{src/data-structures → data-structures}/linked-list/doubly-linked-list.d.ts +0 -0
  703. /package/dist/mjs/{src/data-structures → data-structures}/linked-list/index.d.ts +0 -0
  704. /package/dist/mjs/{src/data-structures → data-structures}/linked-list/singly-linked-list.d.ts +0 -0
  705. /package/dist/mjs/{src/data-structures → data-structures}/linked-list/skip-linked-list.d.ts +0 -0
  706. /package/dist/mjs/{src/data-structures → data-structures}/matrix/index.d.ts +0 -0
  707. /package/dist/mjs/{src/data-structures → data-structures}/matrix/matrix.d.ts +0 -0
  708. /package/dist/mjs/{src/data-structures → data-structures}/matrix/matrix2d.d.ts +0 -0
  709. /package/dist/mjs/{src/data-structures → data-structures}/matrix/navigator.d.ts +0 -0
  710. /package/dist/mjs/{src/data-structures → data-structures}/matrix/vector2d.d.ts +0 -0
  711. /package/dist/mjs/{src/data-structures → data-structures}/priority-queue/index.d.ts +0 -0
  712. /package/dist/mjs/{src/types/data-structures/priority-queue/index.d.ts → data-structures/priority-queue/index.js} +0 -0
  713. /package/dist/mjs/{src/data-structures → data-structures}/priority-queue/max-priority-queue.d.ts +0 -0
  714. /package/dist/mjs/{src/data-structures → data-structures}/priority-queue/min-priority-queue.d.ts +0 -0
  715. /package/dist/mjs/{src/data-structures → data-structures}/priority-queue/priority-queue.d.ts +0 -0
  716. /package/dist/mjs/{src/data-structures → data-structures}/queue/deque.d.ts +0 -0
  717. /package/dist/mjs/{src/data-structures → data-structures}/queue/index.d.ts +0 -0
  718. /package/dist/mjs/{src/types/data-structures/queue/index.d.ts → data-structures/queue/index.js} +0 -0
  719. /package/dist/mjs/{src/data-structures → data-structures}/queue/queue.d.ts +0 -0
  720. /package/dist/mjs/{src/data-structures → data-structures}/stack/index.d.ts +0 -0
  721. /package/dist/mjs/{src/types/data-structures/stack/index.d.ts → data-structures/stack/index.js} +0 -0
  722. /package/dist/mjs/{src/data-structures → data-structures}/stack/stack.d.ts +0 -0
  723. /package/dist/mjs/{src/data-structures → data-structures}/tree/index.d.ts +0 -0
  724. /package/dist/mjs/{src/types/data-structures/tree/index.d.ts → data-structures/tree/index.js} +0 -0
  725. /package/dist/mjs/{src/data-structures → data-structures}/tree/tree.d.ts +0 -0
  726. /package/dist/mjs/{src/data-structures → data-structures}/trie/index.d.ts +0 -0
  727. /package/dist/mjs/{src/types/data-structures/trie/index.d.ts → data-structures/trie/index.js} +0 -0
  728. /package/dist/mjs/{src/data-structures → data-structures}/trie/trie.d.ts +0 -0
  729. /package/dist/mjs/{src/index.d.ts → index.d.ts} +0 -0
  730. /package/dist/mjs/{src/interfaces/doubly-linked-list.d.ts → interfaces/binary-tree.js} +0 -0
  731. /package/dist/mjs/{src/types/data-structures/linked-list → interfaces}/doubly-linked-list.d.ts +0 -0
  732. /package/dist/mjs/{src/interfaces/heap.d.ts → interfaces/doubly-linked-list.js} +0 -0
  733. /package/dist/mjs/{src/interfaces → interfaces}/graph.d.ts +0 -0
  734. /package/dist/mjs/{src/interfaces/navigator.d.ts → interfaces/graph.js} +0 -0
  735. /package/dist/mjs/{src/types/data-structures/heap → interfaces}/heap.d.ts +0 -0
  736. /package/dist/mjs/{src/interfaces/priority-queue.d.ts → interfaces/heap.js} +0 -0
  737. /package/dist/mjs/{src/interfaces → interfaces}/index.d.ts +0 -0
  738. /package/dist/mjs/{src/interfaces/segment-tree.d.ts → interfaces/navigator.d.ts} +0 -0
  739. /package/dist/mjs/{src/interfaces/singly-linked-list.d.ts → interfaces/navigator.js} +0 -0
  740. /package/dist/mjs/{src/types/data-structures/priority-queue → interfaces}/priority-queue.d.ts +0 -0
  741. /package/dist/mjs/{src/types/data-structures/binary-tree/binary-indexed-tree.d.ts → interfaces/priority-queue.js} +0 -0
  742. /package/dist/mjs/{src/types/data-structures/graph/undirected-graph.d.ts → interfaces/segment-tree.d.ts} +0 -0
  743. /package/dist/mjs/{src/types/data-structures/hash/coordinate-map.d.ts → interfaces/segment-tree.js} +0 -0
  744. /package/dist/mjs/{src/types/data-structures/linked-list → interfaces}/singly-linked-list.d.ts +0 -0
  745. /package/dist/mjs/{src/types/data-structures/hash/coordinate-set.d.ts → interfaces/singly-linked-list.js} +0 -0
  746. /package/dist/mjs/{src/types → types}/data-structures/binary-tree/avl-tree.d.ts +0 -0
  747. /package/dist/mjs/{src/types/data-structures/hash/hash-map.d.ts → types/data-structures/binary-tree/avl-tree.js} +0 -0
  748. /package/dist/mjs/{src/types/data-structures/hash/hash-table.d.ts → types/data-structures/binary-tree/binary-indexed-tree.d.ts} +0 -0
  749. /package/dist/mjs/{src/types/data-structures/hash/tree-map.d.ts → types/data-structures/binary-tree/binary-indexed-tree.js} +0 -0
  750. /package/dist/mjs/{src/types → types}/data-structures/binary-tree/binary-tree.d.ts +0 -0
  751. /package/dist/mjs/{src/types → types}/data-structures/binary-tree/bst.d.ts +0 -0
  752. /package/dist/mjs/{src/types/data-structures/hash/tree-set.d.ts → types/data-structures/binary-tree/bst.js} +0 -0
  753. /package/dist/mjs/{src/types → types}/data-structures/binary-tree/index.d.ts +0 -0
  754. /package/dist/mjs/{src/types → types}/data-structures/binary-tree/rb-tree.d.ts +0 -0
  755. /package/dist/mjs/{src/types → types}/data-structures/binary-tree/segment-tree.d.ts +0 -0
  756. /package/dist/mjs/{src/types/data-structures/heap/max-heap.d.ts → types/data-structures/binary-tree/segment-tree.js} +0 -0
  757. /package/dist/mjs/{src/types → types}/data-structures/binary-tree/tree-multimap.d.ts +0 -0
  758. /package/dist/mjs/{src/types/data-structures/heap/min-heap.d.ts → types/data-structures/binary-tree/tree-multimap.js} +0 -0
  759. /package/dist/mjs/{src/types → types}/data-structures/graph/abstract-graph.d.ts +0 -0
  760. /package/dist/mjs/{src/types/data-structures/linked-list/skip-linked-list.d.ts → types/data-structures/graph/abstract-graph.js} +0 -0
  761. /package/dist/mjs/{src/types → types}/data-structures/graph/directed-graph.d.ts +0 -0
  762. /package/dist/mjs/{src/types → types}/data-structures/graph/index.d.ts +0 -0
  763. /package/dist/mjs/{src/types → types}/data-structures/graph/map-graph.d.ts +0 -0
  764. /package/dist/mjs/{src/types/data-structures/matrix/matrix.d.ts → types/data-structures/graph/map-graph.js} +0 -0
  765. /package/dist/mjs/{src/types/data-structures/matrix/matrix2d.d.ts → types/data-structures/graph/undirected-graph.d.ts} +0 -0
  766. /package/dist/mjs/{src/types/data-structures/matrix/vector2d.d.ts → types/data-structures/graph/undirected-graph.js} +0 -0
  767. /package/dist/mjs/{src/types/data-structures/priority-queue/max-priority-queue.d.ts → types/data-structures/hash/coordinate-map.d.ts} +0 -0
  768. /package/dist/mjs/{src/types/data-structures/priority-queue/min-priority-queue.d.ts → types/data-structures/hash/coordinate-map.js} +0 -0
  769. /package/dist/mjs/{src/types/data-structures/queue/deque.d.ts → types/data-structures/hash/coordinate-set.d.ts} +0 -0
  770. /package/dist/mjs/{src/types/data-structures/queue/queue.d.ts → types/data-structures/hash/coordinate-set.js} +0 -0
  771. /package/dist/mjs/{src/types/data-structures/stack/stack.d.ts → types/data-structures/hash/hash-map.d.ts} +0 -0
  772. /package/dist/mjs/{src/types/data-structures/tree/tree.d.ts → types/data-structures/hash/hash-map.js} +0 -0
  773. /package/dist/mjs/{src/types/data-structures/trie/trie.d.ts → types/data-structures/hash/hash-table.d.ts} +0 -0
  774. /package/dist/mjs/{src/types → types}/data-structures/hash/index.d.ts +0 -0
  775. /package/dist/mjs/{src/types → types}/data-structures/heap/index.d.ts +0 -0
  776. /package/dist/mjs/{src/types → types}/data-structures/index.d.ts +0 -0
  777. /package/dist/mjs/{src/types → types}/data-structures/linked-list/index.d.ts +0 -0
  778. /package/dist/mjs/{src/types → types}/data-structures/matrix/index.d.ts +0 -0
  779. /package/dist/mjs/{src/types → types}/data-structures/matrix/navigator.d.ts +0 -0
  780. /package/dist/mjs/{src/types → types}/helpers.d.ts +0 -0
  781. /package/dist/mjs/{src/types → types}/index.d.ts +0 -0
  782. /package/dist/mjs/{src/types → types}/utils/index.d.ts +0 -0
  783. /package/dist/mjs/{src/types → types}/utils/utils.d.ts +0 -0
  784. /package/dist/mjs/{src/types → types}/utils/validate-type.d.ts +0 -0
  785. /package/dist/mjs/{src/utils → utils}/index.d.ts +0 -0
  786. /package/dist/mjs/{src/utils → utils}/utils.d.ts +0 -0
@@ -2,30 +2,29 @@ import {Deque} from '../../../../src';
2
2
  import {Deque as CDeque} from 'js-sdsl';
3
3
  import * as Benchmark from 'benchmark';
4
4
  import {magnitude} from '../../../utils';
5
- import {isCompetitor} from "../../../config";
5
+ import {isCompetitor} from '../../../config';
6
6
 
7
7
  export const suite = new Benchmark.Suite();
8
8
  const {LINEAR} = magnitude;
9
9
 
10
- suite
11
- .add(`${LINEAR.toLocaleString()} push`, () => {
12
- const deque = new Deque<number>();
13
- for (let i = 0; i < LINEAR; i++) {
14
- deque.push(i);
15
- }
16
- })
17
- if (isCompetitor) {
18
- suite.add(`${LINEAR.toLocaleString()} competitor push`, () => {
19
- const deque = new CDeque<number>();
20
- for (let i = 0; i < LINEAR; i++) {
21
- deque.pushBack(i);
22
- }
23
- })
10
+ suite.add(`${LINEAR.toLocaleString()} push`, () => {
11
+ const deque = new Deque<number>();
12
+ for (let i = 0; i < LINEAR; i++) {
13
+ deque.push(i);
24
14
  }
25
- suite.add(`${LINEAR.toLocaleString()} shift`, () => {
26
- const deque = new Deque<number>();
15
+ });
16
+ if (isCompetitor) {
17
+ suite.add(`${LINEAR.toLocaleString()} competitor push`, () => {
18
+ const deque = new CDeque<number>();
27
19
  for (let i = 0; i < LINEAR; i++) {
28
- deque.push(i);
29
- deque.shift();
20
+ deque.pushBack(i);
30
21
  }
31
22
  });
23
+ }
24
+ suite.add(`${LINEAR.toLocaleString()} shift`, () => {
25
+ const deque = new Deque<number>();
26
+ for (let i = 0; i < LINEAR; i++) {
27
+ deque.push(i);
28
+ deque.shift();
29
+ }
30
+ });
@@ -2,35 +2,34 @@ import {Queue} from '../../../../src';
2
2
  import {Queue as CQueue} from 'js-sdsl';
3
3
  import * as Benchmark from 'benchmark';
4
4
  import {magnitude} from '../../../utils';
5
- import {isCompetitor} from "../../../config";
5
+ import {isCompetitor} from '../../../config';
6
6
 
7
7
  const suite = new Benchmark.Suite();
8
8
  const {LINEAR} = magnitude;
9
9
 
10
- suite
11
- .add(`${LINEAR.toLocaleString()} push`, () => {
12
- const queue = new Queue<number>();
10
+ suite.add(`${LINEAR.toLocaleString()} push`, () => {
11
+ const queue = new Queue<number>();
13
12
 
14
- for (let i = 0; i < LINEAR; i++) {
15
- queue.push(i);
16
- }
17
- })
18
- if (isCompetitor) {
19
- suite.add(`${LINEAR.toLocaleString()} competitor push`, () => {
20
- const queue = new CQueue<number>();
21
-
22
- for (let i = 0; i < LINEAR; i++) {
23
- queue.push(i);
24
- }
25
- })
13
+ for (let i = 0; i < LINEAR; i++) {
14
+ queue.push(i);
26
15
  }
27
- suite.add(`${LINEAR.toLocaleString()} push & shift`, () => {
28
- const queue = new Queue<number>();
16
+ });
17
+ if (isCompetitor) {
18
+ suite.add(`${LINEAR.toLocaleString()} competitor push`, () => {
19
+ const queue = new CQueue<number>();
29
20
 
30
21
  for (let i = 0; i < LINEAR; i++) {
31
22
  queue.push(i);
32
- queue.shift();
33
23
  }
34
24
  });
25
+ }
26
+ suite.add(`${LINEAR.toLocaleString()} push & shift`, () => {
27
+ const queue = new Queue<number>();
28
+
29
+ for (let i = 0; i < LINEAR; i++) {
30
+ queue.push(i);
31
+ queue.shift();
32
+ }
33
+ });
35
34
 
36
35
  export {suite};
@@ -2,19 +2,18 @@ import {Stack} from '../../../../src';
2
2
  import {Stack as CStack} from 'js-sdsl';
3
3
  import * as Benchmark from 'benchmark';
4
4
  import {magnitude} from '../../../utils';
5
- import {isCompetitor} from "../../../config";
5
+ import {isCompetitor} from '../../../config';
6
6
 
7
7
  const suite = new Benchmark.Suite();
8
8
  const {LINEAR} = magnitude;
9
9
 
10
- suite
11
- .add(`${LINEAR.toLocaleString()} push`, () => {
12
- const stack = new Stack<number>();
10
+ suite.add(`${LINEAR.toLocaleString()} push`, () => {
11
+ const stack = new Stack<number>();
13
12
 
14
- for (let i = 0; i < LINEAR; i++) {
15
- stack.push(i);
16
- }
17
- })
13
+ for (let i = 0; i < LINEAR; i++) {
14
+ stack.push(i);
15
+ }
16
+ });
18
17
  if (isCompetitor) {
19
18
  suite.add(`${LINEAR.toLocaleString()} competitor push`, () => {
20
19
  const queue = new CStack<number>();
@@ -22,7 +21,7 @@ if (isCompetitor) {
22
21
  for (let i = 0; i < LINEAR; i++) {
23
22
  queue.push(i);
24
23
  }
25
- })
24
+ });
26
25
  }
27
26
  suite.add(`${LINEAR.toLocaleString()} push & pop`, () => {
28
27
  const queue = new Stack<number>();
@@ -33,7 +32,7 @@ suite.add(`${LINEAR.toLocaleString()} push & pop`, () => {
33
32
  for (let i = 0; i < LINEAR; i++) {
34
33
  queue.pop();
35
34
  }
36
- })
35
+ });
37
36
  if (isCompetitor) {
38
37
  suite.add(`${LINEAR.toLocaleString()} competitor push & pop`, () => {
39
38
  const queue = new CStack<number>();
@@ -44,7 +43,7 @@ if (isCompetitor) {
44
43
  for (let i = 0; i < LINEAR; i++) {
45
44
  queue.pop();
46
45
  }
47
- })
46
+ });
48
47
  }
49
48
 
50
49
  export {suite};
@@ -5,7 +5,9 @@ import * as fastGlob from 'fast-glob';
5
5
  import {Color, numberFix, render} from '../utils';
6
6
  import {PerformanceTest} from './types';
7
7
 
8
- const reportDistPath = 'benchmark';
8
+ const parentDirectory = path.resolve(__dirname, '../..');
9
+ const reportDistPath = path.join(parentDirectory, 'benchmark');
10
+
9
11
  const testDir = path.join(__dirname, 'data-structures');
10
12
  const testFiles = fastGlob.sync(path.join(testDir, '**', '*.test.ts'));
11
13
 
@@ -109,7 +111,6 @@ const composeReport = () => {
109
111
  };
110
112
 
111
113
  function replaceMarkdownContent(startMarker: string, endMarker: string, newText: string) {
112
- const parentDirectory = path.resolve(__dirname, '../..'); // The path to the parent directory
113
114
  const filePath = path.join(parentDirectory, 'README.md'); // Path to README.md file
114
115
  fs.readFile(filePath, 'utf8', (err, data) => {
115
116
  if (err) {
@@ -172,9 +173,7 @@ performanceTests.forEach(item => {
172
173
  console.log(
173
174
  // `Files: ${GREEN}${testFileCount}${END} `,
174
175
  // `Suites: ${GREEN}${performanceTests.length}${END} `,
175
- `Suites Progress: ${isDone ? GREEN : YELLOW}${completedCount}${END}/${isDone ? GREEN : YELLOW}${
176
- performanceTests.length
177
- }${END}`,
176
+ `Suites Progress: ${isDone ? GREEN : YELLOW}${completedCount}${END}/${isDone ? GREEN : YELLOW}${performanceTests.length}${END}`,
178
177
  `Time: ${isTimeWarn ? YELLOW : GREEN}${runTime}s${END}`
179
178
  );
180
179
  if (isDone) {
@@ -285,5 +285,4 @@ describe('AVLTree', () => {
285
285
  expect(bfsRes[0]?.key).toBe(2);
286
286
  });
287
287
  });
288
-
289
288
  });
@@ -1,6 +1,6 @@
1
1
  import {BinaryTree, BinaryTreeNode, IterationType} from '../../../../src';
2
- import {getRandomIntArray} from "../../../utils";
3
- import {FamilyPosition} from "binary-tree-typed";
2
+ import {getRandomIntArray} from '../../../utils';
3
+ import {FamilyPosition} from 'binary-tree-typed';
4
4
  // import {isDebugTest} from '../../../config';
5
5
 
6
6
  // const isDebug = isDebugTest;
@@ -72,7 +72,6 @@ describe('BinaryTreeNode', () => {
72
72
  expect(leftChild.familyPosition).toBe('ROOT_LEFT');
73
73
  rightChild.left = new BinaryTreeNode<number>(5);
74
74
  expect(rightChild.familyPosition).toBe('ROOT_RIGHT');
75
-
76
75
  });
77
76
 
78
77
  it('should determine only right child family position correctly', () => {
@@ -106,8 +105,8 @@ describe('BinaryTree', () => {
106
105
  });
107
106
 
108
107
  it('should delete nodes', () => {
109
- expect(tree.getHeight(tree.root, IterationType.ITERATIVE)).toBe(-1)
110
- expect(tree.getMinHeight()).toBe(-1)
108
+ expect(tree.getHeight(tree.root, IterationType.ITERATIVE)).toBe(-1);
109
+ expect(tree.getMinHeight()).toBe(-1);
111
110
  const node = tree.add(1);
112
111
  expect(tree.size).toBe(1);
113
112
 
@@ -117,7 +116,6 @@ describe('BinaryTree', () => {
117
116
  tree.add(rightChild);
118
117
  const root = tree.root;
119
118
 
120
-
121
119
  expect(leftChild.familyPosition).toBe('LEFT');
122
120
  tree.add(null);
123
121
  tree.add(new BinaryTreeNode<number>(4));
@@ -128,15 +126,14 @@ describe('BinaryTree', () => {
128
126
  expect(rightChild.familyPosition).toBe('ROOT_RIGHT');
129
127
 
130
128
  tree.delete(new BinaryTreeNode<number>(200));
131
- tree.delete(rightChild)
129
+ tree.delete(rightChild);
132
130
 
133
131
  if (node) {
134
132
  const result = tree.delete(node);
135
133
  expect(result).toHaveLength(1);
136
134
  expect(tree.size).toBe(3);
137
- expect(tree.getMinHeight(tree.root, IterationType.RECURSIVE)).toBe(1)
135
+ expect(tree.getMinHeight(tree.root, IterationType.RECURSIVE)).toBe(1);
138
136
  }
139
-
140
137
  });
141
138
 
142
139
  it('should add and find nodes', () => {
@@ -155,11 +152,10 @@ describe('BinaryTree', () => {
155
152
  expect(tree.has('3', node => node.value?.toString())).toBe(true);
156
153
  });
157
154
 
158
-
159
155
  it('should be a balance tree after malicious manipulation', () => {
160
156
  tree.add(3);
161
157
  tree.add(12);
162
- tree.addMany(getRandomIntArray(100, 1, 100))
158
+ tree.addMany(getRandomIntArray(100, 1, 100));
163
159
  tree.add(10);
164
160
 
165
161
  expect(tree.isPerfectlyBalanced()).toBe(true);
@@ -238,20 +234,16 @@ describe('BinaryTree', () => {
238
234
 
239
235
  expect(tree.isSubtreeBST(tree.getNode(4), IterationType.RECURSIVE)).toBe(true);
240
236
  expect(tree.isSubtreeBST(tree.getNode(4), IterationType.ITERATIVE)).toBe(true);
241
- expect(tree.getNodes(2, undefined, false, null)).toEqual([])
242
- expect(tree.getNodes(tree.getNodeByKey(2), undefined, false, tree.root)).toEqual([tree.getNodeByKey(2)])
237
+ expect(tree.getNodes(2, undefined, false, null)).toEqual([]);
238
+ expect(tree.getNodes(tree.getNodeByKey(2), undefined, false, tree.root)).toEqual([tree.getNodeByKey(2)]);
243
239
  });
244
240
 
245
241
  it('should subTreeTraverse', () => {
246
242
  tree.addMany([4, 2, 6, null, 1, 3, null, 5, null, 7]);
247
243
  expect(tree.subTreeTraverse(node => node.key, tree.getNode(6), IterationType.ITERATIVE)).toEqual([6, 3, 7]);
248
244
  expect(tree.subTreeTraverse(node => node.key, tree.getNode(6), IterationType.RECURSIVE)).toEqual([6, 3, 7]);
249
- expect(
250
- tree.subTreeTraverse(node => (node ? node.key : null ), tree.getNode(6), IterationType.ITERATIVE, true)
251
- ).toEqual([6, 3, 7, null]);
252
- expect(
253
- tree.subTreeTraverse(node => (node ? node.key : null ), tree.getNode(6), IterationType.RECURSIVE, true)
254
- ).toEqual([6, 3, 7, null]);
245
+ expect(tree.subTreeTraverse(node => (node ? node.key : null), tree.getNode(6), IterationType.ITERATIVE, true)).toEqual([6, 3, 7, null]);
246
+ expect(tree.subTreeTraverse(node => (node ? node.key : null), tree.getNode(6), IterationType.RECURSIVE, true)).toEqual([6, 3, 7, null]);
255
247
  });
256
248
 
257
249
  it('should clear the tree', () => {
@@ -323,46 +315,82 @@ describe('BinaryTree traversals', () => {
323
315
 
324
316
  const arr = [35, 20, 40, 15, 29, null, 50, null, 16, 28, 30, 45, 55];
325
317
  tree.refill(arr);
326
- expect(
327
- tree.bfs(node => node, tree.root, IterationType.ITERATIVE, true).map(node => (node ? node.key : null ))
328
- ).toEqual([35, 20, 40, 15, 29, null, 50, null, 16, 28, 30, 45, 55]);
329
- expect(
330
- tree.bfs(node => node, tree.root, IterationType.RECURSIVE, true).map(node => (node ? node.key : null ))
331
- ).toEqual([35, 20, 40, 15, 29, null, 50, null, 16, 28, 30, 45, 55]);
332
- expect(
333
- tree.bfs(node => node, tree.root, IterationType.ITERATIVE).map(node => (node === null ? null : node.key))
334
- ).toEqual([35, 20, 40, 15, 29, 50, 16, 28, 30, 45, 55]);
335
- expect(
336
- tree.bfs(node => node, tree.root, IterationType.RECURSIVE).map(node => (node === null ? null : node.key))
337
- ).toEqual([35, 20, 40, 15, 29, 50, 16, 28, 30, 45, 55]);
338
-
339
- expect(tree.dfs(node => node.key, 'pre')).toEqual([35, 20, 15, 16, 29, 28, 30, 40, 50, 45, 55]);
340
- expect(tree.dfs(node => node.key, 'pre', tree.root, IterationType.RECURSIVE)).toEqual([
341
- 35, 20, 15, 16, 29, 28, 30, 40, 50, 45, 55
318
+ expect(tree.bfs(node => node, tree.root, IterationType.ITERATIVE, true).map(node => (node ? node.key : null))).toEqual([
319
+ 35,
320
+ 20,
321
+ 40,
322
+ 15,
323
+ 29,
324
+ null,
325
+ 50,
326
+ null,
327
+ 16,
328
+ 28,
329
+ 30,
330
+ 45,
331
+ 55
342
332
  ]);
343
- expect(
344
- tree
345
- .dfs(node => node, 'pre', tree.root, IterationType.ITERATIVE, true)
346
- .map(node => (node ? node.key : null ))
347
- ).toEqual([35, 20, 15, null, 16, 29, 28, 30, 40, null, 50, 45, 55]);
348
- expect(
349
- tree
350
- .dfs(node => node, 'pre', tree.root, IterationType.RECURSIVE, true)
351
- .map(node => (node ? node.key : null ))
352
- ).toEqual([35, 20, 15, null, 16, 29, 28, 30, 40, null, 50, 45, 55]);
353
-
354
- expect(tree.dfs(node => node.key, 'in')).toEqual([15, 16, 20, 28, 29, 30, 35, 40, 45, 50, 55]);
355
- expect(tree.dfs(node => node.key, 'post')).toEqual([16, 15, 28, 30, 29, 20, 45, 55, 50, 40, 35]);
356
- expect(tree.dfs(node => node.key, 'post', tree.root, IterationType.RECURSIVE)).toEqual([
357
- 16, 15, 28, 30, 29, 20, 45, 55, 50, 40, 35
333
+ expect(tree.bfs(node => node, tree.root, IterationType.RECURSIVE, true).map(node => (node ? node.key : null))).toEqual([
334
+ 35,
335
+ 20,
336
+ 40,
337
+ 15,
338
+ 29,
339
+ null,
340
+ 50,
341
+ null,
342
+ 16,
343
+ 28,
344
+ 30,
345
+ 45,
346
+ 55
358
347
  ]);
359
- expect(tree.bfs(node => node.key, tree.root, IterationType.RECURSIVE)).toEqual([
348
+ expect(tree.bfs(node => node, tree.root, IterationType.ITERATIVE).map(node => (node === null ? null : node.key))).toEqual([
360
349
  35, 20, 40, 15, 29, 50, 16, 28, 30, 45, 55
361
350
  ]);
362
- expect(tree.bfs(node => node.key, tree.root, IterationType.ITERATIVE)).toEqual([
351
+ expect(tree.bfs(node => node, tree.root, IterationType.RECURSIVE).map(node => (node === null ? null : node.key))).toEqual([
363
352
  35, 20, 40, 15, 29, 50, 16, 28, 30, 45, 55
364
353
  ]);
365
354
 
355
+ expect(tree.dfs(node => node.key, 'pre')).toEqual([35, 20, 15, 16, 29, 28, 30, 40, 50, 45, 55]);
356
+ expect(tree.dfs(node => node.key, 'pre', tree.root, IterationType.RECURSIVE)).toEqual([35, 20, 15, 16, 29, 28, 30, 40, 50, 45, 55]);
357
+ expect(tree.dfs(node => node, 'pre', tree.root, IterationType.ITERATIVE, true).map(node => (node ? node.key : null))).toEqual([
358
+ 35,
359
+ 20,
360
+ 15,
361
+ null,
362
+ 16,
363
+ 29,
364
+ 28,
365
+ 30,
366
+ 40,
367
+ null,
368
+ 50,
369
+ 45,
370
+ 55
371
+ ]);
372
+ expect(tree.dfs(node => node, 'pre', tree.root, IterationType.RECURSIVE, true).map(node => (node ? node.key : null))).toEqual([
373
+ 35,
374
+ 20,
375
+ 15,
376
+ null,
377
+ 16,
378
+ 29,
379
+ 28,
380
+ 30,
381
+ 40,
382
+ null,
383
+ 50,
384
+ 45,
385
+ 55
386
+ ]);
387
+
388
+ expect(tree.dfs(node => node.key, 'in')).toEqual([15, 16, 20, 28, 29, 30, 35, 40, 45, 50, 55]);
389
+ expect(tree.dfs(node => node.key, 'post')).toEqual([16, 15, 28, 30, 29, 20, 45, 55, 50, 40, 35]);
390
+ expect(tree.dfs(node => node.key, 'post', tree.root, IterationType.RECURSIVE)).toEqual([16, 15, 28, 30, 29, 20, 45, 55, 50, 40, 35]);
391
+ expect(tree.bfs(node => node.key, tree.root, IterationType.RECURSIVE)).toEqual([35, 20, 40, 15, 29, 50, 16, 28, 30, 45, 55]);
392
+ expect(tree.bfs(node => node.key, tree.root, IterationType.ITERATIVE)).toEqual([35, 20, 40, 15, 29, 50, 16, 28, 30, 45, 55]);
393
+
366
394
  expect(tree.listLevels(node => node.key)).toEqual([[35], [20, 40], [15, 29, 50], [16, 28, 30, 45, 55]]);
367
395
 
368
396
  expect(tree.listLevels(node => node.key, tree.root, IterationType.RECURSIVE)).toEqual([
@@ -371,13 +399,13 @@ describe('BinaryTree traversals', () => {
371
399
  [15, 29, 50],
372
400
  [16, 28, 30, 45, 55]
373
401
  ]);
374
- expect(tree.listLevels(node => (node ? node.key : null ), tree.root, IterationType.ITERATIVE, true)).toEqual([
402
+ expect(tree.listLevels(node => (node ? node.key : null), tree.root, IterationType.ITERATIVE, true)).toEqual([
375
403
  [35],
376
404
  [20, 40],
377
405
  [15, 29, null, 50],
378
406
  [null, 16, 28, 30, 45, 55]
379
407
  ]);
380
- expect(tree.listLevels(node => ( node ? node.key : null ), tree.root, IterationType.RECURSIVE, true)).toEqual([
408
+ expect(tree.listLevels(node => (node ? node.key : null), tree.root, IterationType.RECURSIVE, true)).toEqual([
381
409
  [35],
382
410
  [20, 40],
383
411
  [15, 29, null, 50],
@@ -532,13 +560,7 @@ describe('BinaryTree', () => {
532
560
  expect(nodes.length).toBe(1);
533
561
  expect(nodes[0].key).toBe(3);
534
562
 
535
- const nodesRec = tree.getNodes(
536
- 'B',
537
- (node: BinaryTreeNode<string>) => node.value,
538
- false,
539
- tree.root,
540
- IterationType.RECURSIVE
541
- );
563
+ const nodesRec = tree.getNodes('B', (node: BinaryTreeNode<string>) => node.value, false, tree.root, IterationType.RECURSIVE);
542
564
 
543
565
  expect(nodesRec.length).toBe(1);
544
566
  expect(nodesRec[0].key).toBe(3);
@@ -843,11 +843,7 @@ describe('BST Performance test', function () {
843
843
  bst.addMany([4, 2, 6, 1, 3, 5, 7]);
844
844
  expect(bst.subTreeTraverse(node => node.key, bst.getNode(6), IterationType.ITERATIVE)).toEqual([6, 5, 7]);
845
845
  expect(bst.subTreeTraverse(node => node.key, bst.getNode(6), IterationType.RECURSIVE)).toEqual([6, 5, 7]);
846
- expect(
847
- bst.subTreeTraverse(node => (node?.key ?? undefined), bst.getNode(6), IterationType.ITERATIVE, true)
848
- ).toEqual([6, 5, 7]);
849
- expect(
850
- bst.subTreeTraverse(node => (node?.key ?? undefined), bst.getNode(6), IterationType.RECURSIVE, true)
851
- ).toEqual([6, 5, 7]);
846
+ expect(bst.subTreeTraverse(node => node?.key ?? undefined, bst.getNode(6), IterationType.ITERATIVE, true)).toEqual([6, 5, 7]);
847
+ expect(bst.subTreeTraverse(node => node?.key ?? undefined, bst.getNode(6), IterationType.RECURSIVE, true)).toEqual([6, 5, 7]);
852
848
  });
853
849
  });
@@ -1,6 +1,7 @@
1
- import {IterationType, RBTNColor, RedBlackTreeNode, RedBlackTree} from '../../../../src';
2
- import {getRandomInt} from '../../../utils';
1
+ import {IterationType, RBTNColor, RedBlackTree, RedBlackTreeNode} from '../../../../src';
2
+ import {getRandomInt, getRandomIntArray, magnitude} from '../../../utils';
3
3
  import {isDebugTest} from '../../../config';
4
+ import {OrderedMap} from 'js-sdsl';
4
5
 
5
6
  const isDebug = isDebugTest;
6
7
 
@@ -420,14 +421,10 @@ describe('RedBlackTree', () => {
420
421
  isDebug && tree.print();
421
422
 
422
423
  expect(tree.dfs()).toEqual([
423
- 1, 2, 3, 4, 5, 6, 7, 8, 9,
424
- 10, 11, 12, 13, 14, 15, 16, 17, 18,
425
- 19, 22, 23, 25, 28, 33, 50, 110, 111,
426
- 155, 225
427
- ])
424
+ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 22, 23, 25, 28, 33, 50, 110, 111, 155, 225
425
+ ]);
428
426
 
429
427
  expect(tree.isBST()).toBe(true);
430
-
431
428
  });
432
429
 
433
430
  it('should fix the tree after insertion and deletion', () => {
@@ -440,20 +437,14 @@ describe('RedBlackTree', () => {
440
437
 
441
438
  expect(tree.size).toBe(51);
442
439
  expect(tree.isBST()).toBe(true);
443
- expect(tree.dfs( n => n.key, "in", tree.root, IterationType.ITERATIVE)).toEqual([
444
- 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59,
445
- 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70,
446
- 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,
447
- 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92,
448
- 93, 94, 95, 96, 97, 98, 99
449
- ])
450
- expect(tree.dfs( n => n.key, "in", tree.root, IterationType.RECURSIVE)).toEqual([
451
- 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59,
452
- 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70,
453
- 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,
454
- 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92,
455
- 93, 94, 95, 96, 97, 98, 99
456
- ])
440
+ expect(tree.dfs(n => n.key, 'in', tree.root, IterationType.ITERATIVE)).toEqual([
441
+ 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,
442
+ 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99
443
+ ]);
444
+ expect(tree.dfs(n => n.key, 'in', tree.root, IterationType.RECURSIVE)).toEqual([
445
+ 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,
446
+ 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99
447
+ ]);
457
448
  });
458
449
 
459
450
  it('should fix the tree after large scale insertion and deletion', () => {
@@ -466,16 +457,34 @@ describe('RedBlackTree', () => {
466
457
 
467
458
  expect(tree.size).toBe(0);
468
459
  expect(tree.isBST()).toBe(true);
469
- expect(tree.dfs( n => n.key, "in", tree.root, IterationType.ITERATIVE)).toEqual([])
460
+ expect(tree.dfs(n => n.key, 'in', tree.root, IterationType.ITERATIVE)).toEqual([]);
470
461
 
471
462
  tree.clear();
472
463
  for (let i = 0; i < 1000; i++) {
473
- tree.add(getRandomInt(-100, 1000))
474
- tree.delete(getRandomInt(-100, 1000))
464
+ tree.add(getRandomInt(-100, 1000));
465
+ tree.delete(getRandomInt(-100, 1000));
475
466
  }
476
467
 
477
468
  // TODO there is a bug when dfs the tree with NIL node
478
469
  // expect(tree.isBST()).toBe(true);
479
470
  });
471
+ const {HUNDRED_THOUSAND} = magnitude;
472
+ const arr = getRandomIntArray(HUNDRED_THOUSAND, 0, HUNDRED_THOUSAND, true);
473
+ const competitor = new OrderedMap<number, number>();
474
+
475
+ it('should fix the tree after large scale insertion and deletion', () => {
476
+ tree.clear();
477
+ const tS = performance.now();
478
+ for (let i = 0; i < arr.length; i++) {
479
+ tree.add(arr[i]);
480
+ }
481
+ console.log(performance.now() - tS);
482
+
483
+ const cS = performance.now();
480
484
 
485
+ for (let i = 0; i < arr.length; i++) {
486
+ competitor.setElement(arr[i], arr[i]);
487
+ }
488
+ console.log(performance.now() - cS);
489
+ });
481
490
  });
@@ -22,12 +22,12 @@ class MyEdge<E = any> extends AbstractEdge<E> {
22
22
  }
23
23
  }
24
24
 
25
- class MyGraph<
26
- V = any,
27
- E = any,
28
- VO extends MyVertex<V> = MyVertex<V>,
29
- EO extends MyEdge<E> = MyEdge<E>
30
- > extends AbstractGraph<V, E, VO, EO> {
25
+ class MyGraph<V = any, E = any, VO extends MyVertex<V> = MyVertex<V>, EO extends MyEdge<E> = MyEdge<E>> extends AbstractGraph<
26
+ V,
27
+ E,
28
+ VO,
29
+ EO
30
+ > {
31
31
  createVertex(key: VertexKey, value?: V): VO {
32
32
  return new MyVertex(key, value) as VO;
33
33
  }
@@ -126,12 +126,12 @@ class MyEdge<E = any> extends DirectedEdge<E> {
126
126
  }
127
127
  }
128
128
 
129
- class MyDirectedGraph<
130
- V = any,
131
- E = any,
132
- VO extends MyVertex<V> = MyVertex<V>,
133
- EO extends MyEdge<E> = MyEdge<E>
134
- > extends DirectedGraph<V, E, VO, EO> {
129
+ class MyDirectedGraph<V = any, E = any, VO extends MyVertex<V> = MyVertex<V>, EO extends MyEdge<E> = MyEdge<E>> extends DirectedGraph<
130
+ V,
131
+ E,
132
+ VO,
133
+ EO
134
+ > {
135
135
  createVertex(key: VertexKey, value: V): VO {
136
136
  return new MyVertex(key, value) as VO;
137
137
  }
@@ -351,29 +351,9 @@ describe('Inherit from DirectedGraph and perform operations test2.', () => {
351
351
  expect(costs[2]).toEqual([3, 15, 38, 17, 35, Infinity, 64, Infinity, 22]);
352
352
  expect(costs[3]).toEqual([123, 135, 120, 137, 155, Infinity, 47, Infinity, 126]);
353
353
  expect(costs[4]).toEqual([133, 145, 130, 147, 165, Infinity, 57, Infinity, 136]);
354
- expect(costs[5]).toEqual([
355
- Infinity,
356
- Infinity,
357
- Infinity,
358
- Infinity,
359
- Infinity,
360
- Infinity,
361
- Infinity,
362
- Infinity,
363
- Infinity
364
- ]);
354
+ expect(costs[5]).toEqual([Infinity, Infinity, Infinity, Infinity, Infinity, Infinity, Infinity, Infinity, Infinity]);
365
355
  expect(costs[6]).toEqual([76, 88, 73, 90, 108, Infinity, 137, Infinity, 79]);
366
- expect(costs[7]).toEqual([
367
- Infinity,
368
- Infinity,
369
- Infinity,
370
- Infinity,
371
- Infinity,
372
- Infinity,
373
- Infinity,
374
- Infinity,
375
- Infinity
376
- ]);
356
+ expect(costs[7]).toEqual([Infinity, Infinity, Infinity, Infinity, Infinity, Infinity, Infinity, Infinity, Infinity]);
377
357
  expect(costs[8]).toEqual([173, 185, 170, 187, 205, Infinity, 97, Infinity, 176]);
378
358
 
379
359
  expect(predecessor).toBeInstanceOf(Array);
@@ -45,14 +45,7 @@ describe('Heap Operation Test', () => {
45
45
  maxHeap.add({key: 0, a: 'a0'});
46
46
  maxHeap.add({key: 9, a: 'a9'});
47
47
  expect(maxHeap.peek()).toEqual({a: 'a9', key: 9});
48
- expect(maxHeap.toArray().map(item => ({a: item.a}))).toEqual([
49
- {a: 'a9'},
50
- {a: 'a2'},
51
- {a: 'a6'},
52
- {a: 'a1'},
53
- {a: 'a0'},
54
- {a: 'a5'}
55
- ]);
48
+ expect(maxHeap.toArray().map(item => ({a: item.a}))).toEqual([{a: 'a9'}, {a: 'a2'}, {a: 'a6'}, {a: 'a1'}, {a: 'a0'}, {a: 'a5'}]);
56
49
  const maxExpectPolled = [{a: 'a9'}, {a: 'a6'}, {a: 'a5'}, {a: 'a2'}, {a: 'a1'}, {a: 'a0'}];
57
50
  let maxI = 0;
58
51
  while (maxHeap.size > 0) {