data-structure-typed 1.38.1 → 1.38.3

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 (763) hide show
  1. package/CHANGELOG.md +1 -1
  2. package/README.md +1 -1
  3. package/dist/cjs/data-structures/binary-tree/avl-tree.js.map +1 -0
  4. package/dist/cjs/data-structures/binary-tree/binary-indexed-tree.js.map +1 -0
  5. package/dist/{data-structures → cjs/data-structures}/binary-tree/binary-tree.d.ts +9 -9
  6. package/dist/cjs/data-structures/binary-tree/binary-tree.js.map +1 -0
  7. package/{lib → dist/cjs}/data-structures/binary-tree/bst.d.ts +4 -4
  8. package/dist/cjs/data-structures/binary-tree/bst.js.map +1 -0
  9. package/dist/cjs/data-structures/binary-tree/index.js.map +1 -0
  10. package/dist/cjs/data-structures/binary-tree/rb-tree.js.map +1 -0
  11. package/dist/cjs/data-structures/binary-tree/segment-tree.js.map +1 -0
  12. package/dist/cjs/data-structures/binary-tree/tree-multiset.js.map +1 -0
  13. package/dist/cjs/data-structures/graph/abstract-graph.js.map +1 -0
  14. package/dist/cjs/data-structures/graph/directed-graph.js.map +1 -0
  15. package/dist/cjs/data-structures/graph/index.js.map +1 -0
  16. package/dist/cjs/data-structures/graph/map-graph.js.map +1 -0
  17. package/dist/cjs/data-structures/graph/undirected-graph.js.map +1 -0
  18. package/dist/cjs/data-structures/hash/coordinate-map.js.map +1 -0
  19. package/dist/cjs/data-structures/hash/coordinate-set.js.map +1 -0
  20. package/dist/cjs/data-structures/hash/hash-map.js.map +1 -0
  21. package/dist/cjs/data-structures/hash/hash-table.js.map +1 -0
  22. package/dist/cjs/data-structures/hash/index.js.map +1 -0
  23. package/dist/cjs/data-structures/hash/tree-map.js.map +1 -0
  24. package/dist/cjs/data-structures/hash/tree-set.js.map +1 -0
  25. package/dist/cjs/data-structures/heap/heap.js.map +1 -0
  26. package/dist/cjs/data-structures/heap/index.js.map +1 -0
  27. package/dist/cjs/data-structures/heap/max-heap.js.map +1 -0
  28. package/dist/cjs/data-structures/heap/min-heap.js.map +1 -0
  29. package/dist/cjs/data-structures/index.js.map +1 -0
  30. package/dist/cjs/data-structures/linked-list/doubly-linked-list.js.map +1 -0
  31. package/dist/cjs/data-structures/linked-list/index.js.map +1 -0
  32. package/dist/cjs/data-structures/linked-list/singly-linked-list.js.map +1 -0
  33. package/dist/cjs/data-structures/linked-list/skip-linked-list.js.map +1 -0
  34. package/dist/cjs/data-structures/matrix/index.js.map +1 -0
  35. package/dist/cjs/data-structures/matrix/matrix.js.map +1 -0
  36. package/{lib → dist/cjs}/data-structures/matrix/matrix2d.js +13 -5
  37. package/dist/cjs/data-structures/matrix/matrix2d.js.map +1 -0
  38. package/dist/cjs/data-structures/matrix/navigator.js.map +1 -0
  39. package/dist/cjs/data-structures/matrix/vector2d.js.map +1 -0
  40. package/dist/cjs/data-structures/priority-queue/index.js.map +1 -0
  41. package/dist/cjs/data-structures/priority-queue/max-priority-queue.js.map +1 -0
  42. package/dist/cjs/data-structures/priority-queue/min-priority-queue.js.map +1 -0
  43. package/dist/cjs/data-structures/priority-queue/priority-queue.js.map +1 -0
  44. package/dist/cjs/data-structures/queue/deque.js.map +1 -0
  45. package/dist/cjs/data-structures/queue/index.js.map +1 -0
  46. package/dist/cjs/data-structures/queue/queue.js.map +1 -0
  47. package/dist/cjs/data-structures/stack/index.js.map +1 -0
  48. package/dist/cjs/data-structures/stack/stack.js.map +1 -0
  49. package/dist/cjs/data-structures/tree/index.js.map +1 -0
  50. package/dist/cjs/data-structures/tree/tree.js.map +1 -0
  51. package/dist/cjs/data-structures/trie/index.js.map +1 -0
  52. package/dist/cjs/data-structures/trie/trie.js.map +1 -0
  53. package/dist/cjs/index.js.map +1 -0
  54. package/dist/cjs/interfaces/binary-tree.js.map +1 -0
  55. package/dist/cjs/interfaces/doubly-linked-list.js.map +1 -0
  56. package/dist/{interfaces → cjs/interfaces}/graph.js.map +1 -1
  57. package/dist/{interfaces → cjs/interfaces}/heap.js.map +1 -1
  58. package/dist/cjs/interfaces/index.js.map +1 -0
  59. package/dist/{interfaces → cjs/interfaces}/navigator.js.map +1 -1
  60. package/dist/cjs/interfaces/priority-queue.js.map +1 -0
  61. package/dist/cjs/interfaces/segment-tree.js.map +1 -0
  62. package/dist/cjs/interfaces/singly-linked-list.js.map +1 -0
  63. package/dist/cjs/types/data-structures/binary-tree/avl-tree.js.map +1 -0
  64. package/dist/cjs/types/data-structures/binary-tree/binary-indexed-tree.js.map +1 -0
  65. package/{lib → dist/cjs}/types/data-structures/binary-tree/binary-tree.d.ts +1 -1
  66. package/dist/cjs/types/data-structures/binary-tree/binary-tree.js.map +1 -0
  67. package/dist/cjs/types/data-structures/binary-tree/bst.js.map +1 -0
  68. package/dist/cjs/types/data-structures/binary-tree/index.js.map +1 -0
  69. package/dist/cjs/types/data-structures/binary-tree/rb-tree.js.map +1 -0
  70. package/dist/cjs/types/data-structures/binary-tree/segment-tree.js.map +1 -0
  71. package/dist/cjs/types/data-structures/binary-tree/tree-multiset.js.map +1 -0
  72. package/dist/cjs/types/data-structures/graph/abstract-graph.js.map +1 -0
  73. package/dist/cjs/types/data-structures/graph/directed-graph.js.map +1 -0
  74. package/dist/cjs/types/data-structures/graph/index.js.map +1 -0
  75. package/dist/cjs/types/data-structures/graph/map-graph.js.map +1 -0
  76. package/dist/cjs/types/data-structures/graph/undirected-graph.js.map +1 -0
  77. package/dist/cjs/types/data-structures/hash/coordinate-map.js.map +1 -0
  78. package/dist/cjs/types/data-structures/hash/coordinate-set.js.map +1 -0
  79. package/dist/cjs/types/data-structures/hash/hash-map.js.map +1 -0
  80. package/dist/cjs/types/data-structures/hash/hash-table.js.map +1 -0
  81. package/dist/cjs/types/data-structures/hash/index.js.map +1 -0
  82. package/dist/cjs/types/data-structures/hash/tree-map.js.map +1 -0
  83. package/dist/cjs/types/data-structures/hash/tree-set.js.map +1 -0
  84. package/dist/cjs/types/data-structures/heap/heap.js.map +1 -0
  85. package/dist/cjs/types/data-structures/heap/index.js.map +1 -0
  86. package/dist/cjs/types/data-structures/heap/max-heap.js.map +1 -0
  87. package/dist/cjs/types/data-structures/heap/min-heap.js.map +1 -0
  88. package/dist/cjs/types/data-structures/index.js.map +1 -0
  89. package/dist/cjs/types/data-structures/linked-list/doubly-linked-list.js.map +1 -0
  90. package/dist/cjs/types/data-structures/linked-list/index.js.map +1 -0
  91. package/dist/cjs/types/data-structures/linked-list/singly-linked-list.js.map +1 -0
  92. package/dist/cjs/types/data-structures/linked-list/skip-linked-list.js.map +1 -0
  93. package/dist/cjs/types/data-structures/matrix/index.js.map +1 -0
  94. package/dist/cjs/types/data-structures/matrix/matrix.js.map +1 -0
  95. package/dist/cjs/types/data-structures/matrix/matrix2d.js.map +1 -0
  96. package/dist/cjs/types/data-structures/matrix/navigator.js.map +1 -0
  97. package/dist/cjs/types/data-structures/matrix/vector2d.js.map +1 -0
  98. package/dist/cjs/types/data-structures/priority-queue/index.js.map +1 -0
  99. package/dist/cjs/types/data-structures/priority-queue/max-priority-queue.js.map +1 -0
  100. package/dist/cjs/types/data-structures/priority-queue/min-priority-queue.js.map +1 -0
  101. package/dist/cjs/types/data-structures/priority-queue/priority-queue.js.map +1 -0
  102. package/dist/cjs/types/data-structures/queue/deque.js.map +1 -0
  103. package/dist/cjs/types/data-structures/queue/index.js.map +1 -0
  104. package/dist/cjs/types/data-structures/queue/queue.js.map +1 -0
  105. package/dist/cjs/types/data-structures/stack/index.js.map +1 -0
  106. package/dist/cjs/types/data-structures/stack/stack.js.map +1 -0
  107. package/dist/cjs/types/data-structures/tree/index.js.map +1 -0
  108. package/dist/cjs/types/data-structures/tree/tree.js.map +1 -0
  109. package/dist/cjs/types/data-structures/trie/index.js.map +1 -0
  110. package/dist/cjs/types/data-structures/trie/trie.js.map +1 -0
  111. package/{lib → dist/cjs}/types/helpers.d.ts +1 -1
  112. package/dist/cjs/types/helpers.js.map +1 -0
  113. package/dist/cjs/types/index.js.map +1 -0
  114. package/dist/cjs/types/utils/index.js.map +1 -0
  115. package/dist/{types → cjs/types}/utils/utils.js.map +1 -1
  116. package/dist/cjs/types/utils/validate-type.js.map +1 -0
  117. package/dist/cjs/utils/index.js.map +1 -0
  118. package/dist/cjs/utils/utils.js.map +1 -0
  119. package/{lib → dist/mjs}/data-structures/binary-tree/avl-tree.js +10 -4
  120. package/{lib → dist/mjs}/data-structures/binary-tree/binary-indexed-tree.js +12 -3
  121. package/{lib → dist/mjs}/data-structures/binary-tree/binary-tree.d.ts +9 -9
  122. package/{lib → dist/mjs}/data-structures/binary-tree/binary-tree.js +66 -49
  123. package/dist/{data-structures → mjs/data-structures}/binary-tree/bst.d.ts +4 -4
  124. package/{lib → dist/mjs}/data-structures/binary-tree/bst.js +42 -40
  125. package/dist/mjs/data-structures/binary-tree/index.js +23 -0
  126. package/dist/mjs/data-structures/binary-tree/rb-tree.js +28 -0
  127. package/{lib → dist/mjs}/data-structures/binary-tree/segment-tree.js +17 -10
  128. package/{lib → dist/mjs}/data-structures/binary-tree/tree-multiset.js +19 -13
  129. package/{lib → dist/mjs}/data-structures/graph/abstract-graph.js +29 -24
  130. package/{lib → dist/mjs}/data-structures/graph/directed-graph.js +22 -14
  131. package/dist/mjs/data-structures/graph/index.js +20 -0
  132. package/{lib → dist/mjs}/data-structures/graph/map-graph.js +14 -5
  133. package/{lib → dist/mjs}/data-structures/graph/undirected-graph.js +19 -13
  134. package/{lib → dist/mjs}/data-structures/hash/coordinate-map.js +6 -2
  135. package/{lib → dist/mjs}/data-structures/hash/coordinate-set.js +6 -2
  136. package/{lib → dist/mjs}/data-structures/hash/hash-map.js +11 -1
  137. package/{lib → dist/mjs}/data-structures/hash/hash-table.js +16 -4
  138. package/dist/mjs/data-structures/hash/index.js +22 -0
  139. package/dist/mjs/data-structures/hash/tree-map.js +6 -0
  140. package/dist/mjs/data-structures/hash/tree-set.js +6 -0
  141. package/{lib → dist/mjs}/data-structures/heap/heap.js +23 -7
  142. package/dist/mjs/data-structures/heap/index.js +19 -0
  143. package/{lib → dist/mjs}/data-structures/heap/max-heap.js +6 -2
  144. package/{lib → dist/mjs}/data-structures/heap/min-heap.js +6 -2
  145. package/dist/mjs/data-structures/index.js +27 -0
  146. package/{lib → dist/mjs}/data-structures/linked-list/doubly-linked-list.js +15 -6
  147. package/dist/mjs/data-structures/linked-list/index.js +19 -0
  148. package/{lib → dist/mjs}/data-structures/linked-list/singly-linked-list.js +12 -2
  149. package/{lib → dist/mjs}/data-structures/linked-list/skip-linked-list.js +14 -2
  150. package/dist/mjs/data-structures/matrix/index.js +20 -0
  151. package/{lib → dist/mjs}/data-structures/matrix/matrix.js +6 -1
  152. package/dist/{data-structures → mjs/data-structures}/matrix/matrix2d.js +5 -2
  153. package/{lib → dist/mjs}/data-structures/matrix/navigator.js +14 -2
  154. package/{lib → dist/mjs}/data-structures/matrix/vector2d.js +9 -2
  155. package/dist/mjs/data-structures/priority-queue/index.js +19 -0
  156. package/{lib → dist/mjs}/data-structures/priority-queue/max-priority-queue.js +6 -2
  157. package/{lib → dist/mjs}/data-structures/priority-queue/min-priority-queue.js +6 -2
  158. package/dist/mjs/data-structures/priority-queue/priority-queue.js +17 -0
  159. package/{lib → dist/mjs}/data-structures/queue/deque.js +21 -22
  160. package/dist/mjs/data-structures/queue/index.js +18 -0
  161. package/{lib → dist/mjs}/data-structures/queue/queue.js +11 -5
  162. package/dist/mjs/data-structures/stack/index.js +17 -0
  163. package/{lib → dist/mjs}/data-structures/stack/stack.js +6 -1
  164. package/dist/mjs/data-structures/tree/index.js +17 -0
  165. package/{lib → dist/mjs}/data-structures/tree/tree.js +8 -1
  166. package/dist/mjs/data-structures/trie/index.js +17 -0
  167. package/{lib → dist/mjs}/data-structures/trie/trie.js +12 -2
  168. package/dist/mjs/index.js +20 -0
  169. package/dist/mjs/interfaces/binary-tree.js +2 -0
  170. package/dist/mjs/interfaces/doubly-linked-list.js +2 -0
  171. package/dist/mjs/interfaces/graph.js +2 -0
  172. package/dist/mjs/interfaces/heap.js +2 -0
  173. package/dist/mjs/interfaces/index.js +24 -0
  174. package/dist/mjs/interfaces/navigator.js +2 -0
  175. package/dist/mjs/interfaces/priority-queue.js +2 -0
  176. package/dist/mjs/interfaces/segment-tree.js +2 -0
  177. package/dist/mjs/interfaces/singly-linked-list.js +2 -0
  178. package/dist/mjs/types/data-structures/binary-tree/avl-tree.js +2 -0
  179. package/dist/mjs/types/data-structures/binary-tree/binary-indexed-tree.js +2 -0
  180. package/dist/{types → mjs/types}/data-structures/binary-tree/binary-tree.d.ts +1 -1
  181. package/{lib → dist/mjs}/types/data-structures/binary-tree/binary-tree.js +7 -4
  182. package/dist/mjs/types/data-structures/binary-tree/bst.js +2 -0
  183. package/dist/mjs/types/data-structures/binary-tree/index.js +22 -0
  184. package/dist/mjs/types/data-structures/binary-tree/rb-tree.js +8 -0
  185. package/dist/mjs/types/data-structures/binary-tree/segment-tree.js +2 -0
  186. package/dist/mjs/types/data-structures/binary-tree/tree-multiset.js +2 -0
  187. package/dist/mjs/types/data-structures/graph/abstract-graph.js +2 -0
  188. package/dist/mjs/types/data-structures/graph/directed-graph.js +9 -0
  189. package/dist/mjs/types/data-structures/graph/index.js +19 -0
  190. package/dist/mjs/types/data-structures/graph/map-graph.js +2 -0
  191. package/dist/mjs/types/data-structures/graph/undirected-graph.js +2 -0
  192. package/dist/mjs/types/data-structures/hash/coordinate-map.js +2 -0
  193. package/dist/mjs/types/data-structures/hash/coordinate-set.js +2 -0
  194. package/dist/mjs/types/data-structures/hash/hash-map.js +2 -0
  195. package/dist/mjs/types/data-structures/hash/hash-table.js +2 -0
  196. package/dist/mjs/types/data-structures/hash/index.js +2 -0
  197. package/dist/mjs/types/data-structures/hash/tree-map.js +2 -0
  198. package/dist/mjs/types/data-structures/hash/tree-set.js +2 -0
  199. package/dist/mjs/types/data-structures/heap/heap.js +2 -0
  200. package/dist/mjs/types/data-structures/heap/index.js +17 -0
  201. package/dist/mjs/types/data-structures/heap/max-heap.js +2 -0
  202. package/dist/mjs/types/data-structures/heap/min-heap.js +2 -0
  203. package/dist/mjs/types/data-structures/index.js +27 -0
  204. package/dist/mjs/types/data-structures/linked-list/doubly-linked-list.js +2 -0
  205. package/dist/mjs/types/data-structures/linked-list/index.js +18 -0
  206. package/dist/mjs/types/data-structures/linked-list/singly-linked-list.js +2 -0
  207. package/dist/mjs/types/data-structures/linked-list/skip-linked-list.js +2 -0
  208. package/dist/mjs/types/data-structures/matrix/index.js +17 -0
  209. package/dist/mjs/types/data-structures/matrix/matrix.js +2 -0
  210. package/dist/mjs/types/data-structures/matrix/matrix2d.js +2 -0
  211. package/dist/mjs/types/data-structures/matrix/navigator.js +2 -0
  212. package/dist/mjs/types/data-structures/matrix/vector2d.js +2 -0
  213. package/dist/mjs/types/data-structures/priority-queue/index.js +19 -0
  214. package/dist/mjs/types/data-structures/priority-queue/max-priority-queue.js +2 -0
  215. package/dist/mjs/types/data-structures/priority-queue/min-priority-queue.js +2 -0
  216. package/dist/mjs/types/data-structures/priority-queue/priority-queue.js +2 -0
  217. package/dist/mjs/types/data-structures/queue/deque.js +2 -0
  218. package/dist/mjs/types/data-structures/queue/index.js +18 -0
  219. package/dist/mjs/types/data-structures/queue/queue.js +2 -0
  220. package/dist/mjs/types/data-structures/stack/index.js +17 -0
  221. package/dist/mjs/types/data-structures/stack/stack.js +2 -0
  222. package/dist/mjs/types/data-structures/tree/index.js +17 -0
  223. package/dist/mjs/types/data-structures/tree/tree.js +2 -0
  224. package/dist/mjs/types/data-structures/trie/index.js +17 -0
  225. package/dist/mjs/types/data-structures/trie/trie.js +2 -0
  226. package/dist/{types → mjs/types}/helpers.d.ts +1 -1
  227. package/dist/mjs/types/helpers.js +9 -0
  228. package/dist/mjs/types/index.js +19 -0
  229. package/dist/mjs/types/utils/index.js +18 -0
  230. package/dist/mjs/types/utils/utils.js +2 -0
  231. package/dist/mjs/types/utils/validate-type.js +2 -0
  232. package/dist/mjs/utils/index.js +17 -0
  233. package/dist/mjs/utils/utils.js +64 -0
  234. package/dist/umd/index.global.js +27 -0
  235. package/dist/umd/index.global.js.map +1 -0
  236. package/package.json +21 -23
  237. package/src/data-structures/binary-tree/binary-tree.ts +19 -19
  238. package/src/data-structures/binary-tree/bst.ts +7 -7
  239. package/src/types/data-structures/binary-tree/binary-tree.ts +1 -1
  240. package/src/types/helpers.ts +1 -1
  241. package/test/integration/index.html +3 -4
  242. package/test/unit/data-structures/binary-tree/avl-tree.test.ts +23 -7
  243. package/test/unit/data-structures/binary-tree/binary-index-tree.test.ts +2 -1
  244. package/test/unit/data-structures/binary-tree/binary-tree.test.ts +20 -1
  245. package/test/unit/data-structures/hash/hash-table.test.ts +1 -1
  246. package/test/unit/data-structures/matrix/navigator.test.ts +1 -1
  247. package/test/unit/data-structures/queue/deque.test.ts +1 -1
  248. package/test/unit/data-structures/queue/queue.test.ts +1 -1
  249. package/tsconfig-base.json +27 -0
  250. package/tsconfig-cjs.json +9 -0
  251. package/tsup.config.js +11 -0
  252. package/umd/bundle.min.js +1 -1
  253. package/umd/bundle.min.js.map +1 -1
  254. package/dist/data-structures/binary-tree/avl-tree.js.map +0 -1
  255. package/dist/data-structures/binary-tree/binary-indexed-tree.js.map +0 -1
  256. package/dist/data-structures/binary-tree/binary-tree.js.map +0 -1
  257. package/dist/data-structures/binary-tree/bst.js.map +0 -1
  258. package/dist/data-structures/binary-tree/index.js.map +0 -1
  259. package/dist/data-structures/binary-tree/rb-tree.js.map +0 -1
  260. package/dist/data-structures/binary-tree/segment-tree.js.map +0 -1
  261. package/dist/data-structures/binary-tree/tree-multiset.js.map +0 -1
  262. package/dist/data-structures/graph/abstract-graph.js.map +0 -1
  263. package/dist/data-structures/graph/directed-graph.js.map +0 -1
  264. package/dist/data-structures/graph/index.js.map +0 -1
  265. package/dist/data-structures/graph/map-graph.js.map +0 -1
  266. package/dist/data-structures/graph/undirected-graph.js.map +0 -1
  267. package/dist/data-structures/hash/coordinate-map.js.map +0 -1
  268. package/dist/data-structures/hash/coordinate-set.js.map +0 -1
  269. package/dist/data-structures/hash/hash-map.js.map +0 -1
  270. package/dist/data-structures/hash/hash-table.js.map +0 -1
  271. package/dist/data-structures/hash/index.js.map +0 -1
  272. package/dist/data-structures/hash/tree-map.js.map +0 -1
  273. package/dist/data-structures/hash/tree-set.js.map +0 -1
  274. package/dist/data-structures/heap/heap.js.map +0 -1
  275. package/dist/data-structures/heap/index.js.map +0 -1
  276. package/dist/data-structures/heap/max-heap.js.map +0 -1
  277. package/dist/data-structures/heap/min-heap.js.map +0 -1
  278. package/dist/data-structures/index.js.map +0 -1
  279. package/dist/data-structures/linked-list/doubly-linked-list.js.map +0 -1
  280. package/dist/data-structures/linked-list/index.js.map +0 -1
  281. package/dist/data-structures/linked-list/singly-linked-list.js.map +0 -1
  282. package/dist/data-structures/linked-list/skip-linked-list.js.map +0 -1
  283. package/dist/data-structures/matrix/index.js.map +0 -1
  284. package/dist/data-structures/matrix/matrix.js.map +0 -1
  285. package/dist/data-structures/matrix/matrix2d.js.map +0 -1
  286. package/dist/data-structures/matrix/navigator.js.map +0 -1
  287. package/dist/data-structures/matrix/vector2d.js.map +0 -1
  288. package/dist/data-structures/priority-queue/index.js.map +0 -1
  289. package/dist/data-structures/priority-queue/max-priority-queue.js.map +0 -1
  290. package/dist/data-structures/priority-queue/min-priority-queue.js.map +0 -1
  291. package/dist/data-structures/priority-queue/priority-queue.js.map +0 -1
  292. package/dist/data-structures/queue/deque.js.map +0 -1
  293. package/dist/data-structures/queue/index.js.map +0 -1
  294. package/dist/data-structures/queue/queue.js.map +0 -1
  295. package/dist/data-structures/stack/index.js.map +0 -1
  296. package/dist/data-structures/stack/stack.js.map +0 -1
  297. package/dist/data-structures/tree/index.js.map +0 -1
  298. package/dist/data-structures/tree/tree.js.map +0 -1
  299. package/dist/data-structures/trie/index.js.map +0 -1
  300. package/dist/data-structures/trie/trie.js.map +0 -1
  301. package/dist/index.js.map +0 -1
  302. package/dist/interfaces/binary-tree.js.map +0 -1
  303. package/dist/interfaces/doubly-linked-list.js.map +0 -1
  304. package/dist/interfaces/index.js.map +0 -1
  305. package/dist/interfaces/priority-queue.js.map +0 -1
  306. package/dist/interfaces/segment-tree.js.map +0 -1
  307. package/dist/interfaces/singly-linked-list.js.map +0 -1
  308. package/dist/types/data-structures/binary-tree/avl-tree.js.map +0 -1
  309. package/dist/types/data-structures/binary-tree/binary-indexed-tree.js.map +0 -1
  310. package/dist/types/data-structures/binary-tree/binary-tree.js.map +0 -1
  311. package/dist/types/data-structures/binary-tree/bst.js.map +0 -1
  312. package/dist/types/data-structures/binary-tree/index.js.map +0 -1
  313. package/dist/types/data-structures/binary-tree/rb-tree.js.map +0 -1
  314. package/dist/types/data-structures/binary-tree/segment-tree.js.map +0 -1
  315. package/dist/types/data-structures/binary-tree/tree-multiset.js.map +0 -1
  316. package/dist/types/data-structures/graph/abstract-graph.js.map +0 -1
  317. package/dist/types/data-structures/graph/directed-graph.js.map +0 -1
  318. package/dist/types/data-structures/graph/index.js.map +0 -1
  319. package/dist/types/data-structures/graph/map-graph.js.map +0 -1
  320. package/dist/types/data-structures/graph/undirected-graph.js.map +0 -1
  321. package/dist/types/data-structures/hash/coordinate-map.js.map +0 -1
  322. package/dist/types/data-structures/hash/coordinate-set.js.map +0 -1
  323. package/dist/types/data-structures/hash/hash-map.js.map +0 -1
  324. package/dist/types/data-structures/hash/hash-table.js.map +0 -1
  325. package/dist/types/data-structures/hash/index.js.map +0 -1
  326. package/dist/types/data-structures/hash/tree-map.js.map +0 -1
  327. package/dist/types/data-structures/hash/tree-set.js.map +0 -1
  328. package/dist/types/data-structures/heap/heap.js.map +0 -1
  329. package/dist/types/data-structures/heap/index.js.map +0 -1
  330. package/dist/types/data-structures/heap/max-heap.js.map +0 -1
  331. package/dist/types/data-structures/heap/min-heap.js.map +0 -1
  332. package/dist/types/data-structures/index.js.map +0 -1
  333. package/dist/types/data-structures/linked-list/doubly-linked-list.js.map +0 -1
  334. package/dist/types/data-structures/linked-list/index.js.map +0 -1
  335. package/dist/types/data-structures/linked-list/singly-linked-list.js.map +0 -1
  336. package/dist/types/data-structures/linked-list/skip-linked-list.js.map +0 -1
  337. package/dist/types/data-structures/matrix/index.js.map +0 -1
  338. package/dist/types/data-structures/matrix/matrix.js.map +0 -1
  339. package/dist/types/data-structures/matrix/matrix2d.js.map +0 -1
  340. package/dist/types/data-structures/matrix/navigator.js.map +0 -1
  341. package/dist/types/data-structures/matrix/vector2d.js.map +0 -1
  342. package/dist/types/data-structures/priority-queue/index.js.map +0 -1
  343. package/dist/types/data-structures/priority-queue/max-priority-queue.js.map +0 -1
  344. package/dist/types/data-structures/priority-queue/min-priority-queue.js.map +0 -1
  345. package/dist/types/data-structures/priority-queue/priority-queue.js.map +0 -1
  346. package/dist/types/data-structures/queue/deque.js.map +0 -1
  347. package/dist/types/data-structures/queue/index.js.map +0 -1
  348. package/dist/types/data-structures/queue/queue.js.map +0 -1
  349. package/dist/types/data-structures/stack/index.js.map +0 -1
  350. package/dist/types/data-structures/stack/stack.js.map +0 -1
  351. package/dist/types/data-structures/tree/index.js.map +0 -1
  352. package/dist/types/data-structures/tree/tree.js.map +0 -1
  353. package/dist/types/data-structures/trie/index.js.map +0 -1
  354. package/dist/types/data-structures/trie/trie.js.map +0 -1
  355. package/dist/types/helpers.js.map +0 -1
  356. package/dist/types/index.js.map +0 -1
  357. package/dist/types/utils/index.js.map +0 -1
  358. package/dist/types/utils/validate-type.js.map +0 -1
  359. package/dist/utils/index.js.map +0 -1
  360. package/dist/utils/utils.js.map +0 -1
  361. package/lib/data-structures/binary-tree/index.js +0 -7
  362. package/lib/data-structures/binary-tree/rb-tree.js +0 -22
  363. package/lib/data-structures/graph/index.js +0 -4
  364. package/lib/data-structures/hash/index.js +0 -6
  365. package/lib/data-structures/hash/tree-map.js +0 -2
  366. package/lib/data-structures/hash/tree-set.js +0 -2
  367. package/lib/data-structures/heap/index.js +0 -3
  368. package/lib/data-structures/index.js +0 -11
  369. package/lib/data-structures/linked-list/index.js +0 -3
  370. package/lib/data-structures/matrix/index.js +0 -4
  371. package/lib/data-structures/priority-queue/index.js +0 -3
  372. package/lib/data-structures/priority-queue/priority-queue.js +0 -13
  373. package/lib/data-structures/queue/index.js +0 -2
  374. package/lib/data-structures/stack/index.js +0 -1
  375. package/lib/data-structures/tree/index.js +0 -1
  376. package/lib/data-structures/trie/index.js +0 -1
  377. package/lib/index.js +0 -4
  378. package/lib/interfaces/binary-tree.js +0 -1
  379. package/lib/interfaces/doubly-linked-list.js +0 -1
  380. package/lib/interfaces/graph.js +0 -1
  381. package/lib/interfaces/heap.js +0 -1
  382. package/lib/interfaces/index.js +0 -8
  383. package/lib/interfaces/navigator.js +0 -1
  384. package/lib/interfaces/priority-queue.js +0 -1
  385. package/lib/interfaces/segment-tree.js +0 -1
  386. package/lib/interfaces/singly-linked-list.js +0 -1
  387. package/lib/types/data-structures/binary-tree/avl-tree.js +0 -1
  388. package/lib/types/data-structures/binary-tree/binary-indexed-tree.js +0 -1
  389. package/lib/types/data-structures/binary-tree/bst.js +0 -1
  390. package/lib/types/data-structures/binary-tree/index.js +0 -6
  391. package/lib/types/data-structures/binary-tree/rb-tree.js +0 -5
  392. package/lib/types/data-structures/binary-tree/segment-tree.js +0 -1
  393. package/lib/types/data-structures/binary-tree/tree-multiset.js +0 -1
  394. package/lib/types/data-structures/graph/abstract-graph.js +0 -1
  395. package/lib/types/data-structures/graph/directed-graph.js +0 -6
  396. package/lib/types/data-structures/graph/index.js +0 -3
  397. package/lib/types/data-structures/graph/map-graph.js +0 -1
  398. package/lib/types/data-structures/graph/undirected-graph.js +0 -1
  399. package/lib/types/data-structures/hash/coordinate-map.js +0 -1
  400. package/lib/types/data-structures/hash/coordinate-set.js +0 -1
  401. package/lib/types/data-structures/hash/hash-map.js +0 -1
  402. package/lib/types/data-structures/hash/hash-table.js +0 -1
  403. package/lib/types/data-structures/hash/index.js +0 -1
  404. package/lib/types/data-structures/hash/tree-map.js +0 -1
  405. package/lib/types/data-structures/hash/tree-set.js +0 -1
  406. package/lib/types/data-structures/heap/heap.js +0 -1
  407. package/lib/types/data-structures/heap/index.js +0 -1
  408. package/lib/types/data-structures/heap/max-heap.js +0 -1
  409. package/lib/types/data-structures/heap/min-heap.js +0 -1
  410. package/lib/types/data-structures/index.js +0 -11
  411. package/lib/types/data-structures/linked-list/doubly-linked-list.js +0 -1
  412. package/lib/types/data-structures/linked-list/index.js +0 -2
  413. package/lib/types/data-structures/linked-list/singly-linked-list.js +0 -1
  414. package/lib/types/data-structures/linked-list/skip-linked-list.js +0 -1
  415. package/lib/types/data-structures/matrix/index.js +0 -1
  416. package/lib/types/data-structures/matrix/matrix.js +0 -1
  417. package/lib/types/data-structures/matrix/matrix2d.js +0 -1
  418. package/lib/types/data-structures/matrix/navigator.js +0 -1
  419. package/lib/types/data-structures/matrix/vector2d.js +0 -1
  420. package/lib/types/data-structures/priority-queue/index.js +0 -3
  421. package/lib/types/data-structures/priority-queue/max-priority-queue.js +0 -1
  422. package/lib/types/data-structures/priority-queue/min-priority-queue.js +0 -1
  423. package/lib/types/data-structures/priority-queue/priority-queue.js +0 -1
  424. package/lib/types/data-structures/queue/deque.js +0 -1
  425. package/lib/types/data-structures/queue/index.js +0 -2
  426. package/lib/types/data-structures/queue/queue.js +0 -1
  427. package/lib/types/data-structures/stack/index.js +0 -1
  428. package/lib/types/data-structures/stack/stack.js +0 -1
  429. package/lib/types/data-structures/tree/index.js +0 -1
  430. package/lib/types/data-structures/tree/tree.js +0 -1
  431. package/lib/types/data-structures/trie/index.js +0 -1
  432. package/lib/types/data-structures/trie/trie.js +0 -1
  433. package/lib/types/helpers.js +0 -6
  434. package/lib/types/index.js +0 -3
  435. package/lib/types/utils/index.js +0 -2
  436. package/lib/types/utils/utils.js +0 -1
  437. package/lib/types/utils/validate-type.js +0 -1
  438. package/lib/utils/index.js +0 -1
  439. package/lib/utils/utils.js +0 -63
  440. /package/dist/{data-structures → cjs/data-structures}/binary-tree/avl-tree.d.ts +0 -0
  441. /package/dist/{data-structures → cjs/data-structures}/binary-tree/avl-tree.js +0 -0
  442. /package/dist/{data-structures → cjs/data-structures}/binary-tree/binary-indexed-tree.d.ts +0 -0
  443. /package/dist/{data-structures → cjs/data-structures}/binary-tree/binary-indexed-tree.js +0 -0
  444. /package/dist/{data-structures → cjs/data-structures}/binary-tree/binary-tree.js +0 -0
  445. /package/dist/{data-structures → cjs/data-structures}/binary-tree/bst.js +0 -0
  446. /package/dist/{data-structures → cjs/data-structures}/binary-tree/index.d.ts +0 -0
  447. /package/dist/{data-structures → cjs/data-structures}/binary-tree/index.js +0 -0
  448. /package/dist/{data-structures → cjs/data-structures}/binary-tree/rb-tree.d.ts +0 -0
  449. /package/dist/{data-structures → cjs/data-structures}/binary-tree/rb-tree.js +0 -0
  450. /package/dist/{data-structures → cjs/data-structures}/binary-tree/segment-tree.d.ts +0 -0
  451. /package/dist/{data-structures → cjs/data-structures}/binary-tree/segment-tree.js +0 -0
  452. /package/dist/{data-structures → cjs/data-structures}/binary-tree/tree-multiset.d.ts +0 -0
  453. /package/dist/{data-structures → cjs/data-structures}/binary-tree/tree-multiset.js +0 -0
  454. /package/dist/{data-structures → cjs/data-structures}/graph/abstract-graph.d.ts +0 -0
  455. /package/dist/{data-structures → cjs/data-structures}/graph/abstract-graph.js +0 -0
  456. /package/dist/{data-structures → cjs/data-structures}/graph/directed-graph.d.ts +0 -0
  457. /package/dist/{data-structures → cjs/data-structures}/graph/directed-graph.js +0 -0
  458. /package/dist/{data-structures → cjs/data-structures}/graph/index.d.ts +0 -0
  459. /package/dist/{data-structures → cjs/data-structures}/graph/index.js +0 -0
  460. /package/dist/{data-structures → cjs/data-structures}/graph/map-graph.d.ts +0 -0
  461. /package/dist/{data-structures → cjs/data-structures}/graph/map-graph.js +0 -0
  462. /package/dist/{data-structures → cjs/data-structures}/graph/undirected-graph.d.ts +0 -0
  463. /package/dist/{data-structures → cjs/data-structures}/graph/undirected-graph.js +0 -0
  464. /package/dist/{data-structures → cjs/data-structures}/hash/coordinate-map.d.ts +0 -0
  465. /package/dist/{data-structures → cjs/data-structures}/hash/coordinate-map.js +0 -0
  466. /package/dist/{data-structures → cjs/data-structures}/hash/coordinate-set.d.ts +0 -0
  467. /package/dist/{data-structures → cjs/data-structures}/hash/coordinate-set.js +0 -0
  468. /package/dist/{data-structures → cjs/data-structures}/hash/hash-map.d.ts +0 -0
  469. /package/dist/{data-structures → cjs/data-structures}/hash/hash-map.js +0 -0
  470. /package/dist/{data-structures → cjs/data-structures}/hash/hash-table.d.ts +0 -0
  471. /package/dist/{data-structures → cjs/data-structures}/hash/hash-table.js +0 -0
  472. /package/dist/{data-structures → cjs/data-structures}/hash/index.d.ts +0 -0
  473. /package/dist/{data-structures → cjs/data-structures}/hash/index.js +0 -0
  474. /package/dist/{data-structures → cjs/data-structures}/hash/tree-map.d.ts +0 -0
  475. /package/dist/{data-structures → cjs/data-structures}/hash/tree-map.js +0 -0
  476. /package/dist/{data-structures → cjs/data-structures}/hash/tree-set.d.ts +0 -0
  477. /package/dist/{data-structures → cjs/data-structures}/hash/tree-set.js +0 -0
  478. /package/dist/{data-structures → cjs/data-structures}/heap/heap.d.ts +0 -0
  479. /package/dist/{data-structures → cjs/data-structures}/heap/heap.js +0 -0
  480. /package/dist/{data-structures → cjs/data-structures}/heap/index.d.ts +0 -0
  481. /package/dist/{data-structures → cjs/data-structures}/heap/index.js +0 -0
  482. /package/dist/{data-structures → cjs/data-structures}/heap/max-heap.d.ts +0 -0
  483. /package/dist/{data-structures → cjs/data-structures}/heap/max-heap.js +0 -0
  484. /package/dist/{data-structures → cjs/data-structures}/heap/min-heap.d.ts +0 -0
  485. /package/dist/{data-structures → cjs/data-structures}/heap/min-heap.js +0 -0
  486. /package/dist/{data-structures → cjs/data-structures}/index.d.ts +0 -0
  487. /package/dist/{data-structures → cjs/data-structures}/index.js +0 -0
  488. /package/dist/{data-structures → cjs/data-structures}/linked-list/doubly-linked-list.d.ts +0 -0
  489. /package/dist/{data-structures → cjs/data-structures}/linked-list/doubly-linked-list.js +0 -0
  490. /package/dist/{data-structures → cjs/data-structures}/linked-list/index.d.ts +0 -0
  491. /package/dist/{data-structures → cjs/data-structures}/linked-list/index.js +0 -0
  492. /package/dist/{data-structures → cjs/data-structures}/linked-list/singly-linked-list.d.ts +0 -0
  493. /package/dist/{data-structures → cjs/data-structures}/linked-list/singly-linked-list.js +0 -0
  494. /package/dist/{data-structures → cjs/data-structures}/linked-list/skip-linked-list.d.ts +0 -0
  495. /package/dist/{data-structures → cjs/data-structures}/linked-list/skip-linked-list.js +0 -0
  496. /package/dist/{data-structures → cjs/data-structures}/matrix/index.d.ts +0 -0
  497. /package/dist/{data-structures → cjs/data-structures}/matrix/index.js +0 -0
  498. /package/dist/{data-structures → cjs/data-structures}/matrix/matrix.d.ts +0 -0
  499. /package/dist/{data-structures → cjs/data-structures}/matrix/matrix.js +0 -0
  500. /package/dist/{data-structures → cjs/data-structures}/matrix/matrix2d.d.ts +0 -0
  501. /package/dist/{data-structures → cjs/data-structures}/matrix/navigator.d.ts +0 -0
  502. /package/dist/{data-structures → cjs/data-structures}/matrix/navigator.js +0 -0
  503. /package/dist/{data-structures → cjs/data-structures}/matrix/vector2d.d.ts +0 -0
  504. /package/dist/{data-structures → cjs/data-structures}/matrix/vector2d.js +0 -0
  505. /package/dist/{data-structures → cjs/data-structures}/priority-queue/index.d.ts +0 -0
  506. /package/dist/{data-structures → cjs/data-structures}/priority-queue/index.js +0 -0
  507. /package/dist/{data-structures → cjs/data-structures}/priority-queue/max-priority-queue.d.ts +0 -0
  508. /package/dist/{data-structures → cjs/data-structures}/priority-queue/max-priority-queue.js +0 -0
  509. /package/dist/{data-structures → cjs/data-structures}/priority-queue/min-priority-queue.d.ts +0 -0
  510. /package/dist/{data-structures → cjs/data-structures}/priority-queue/min-priority-queue.js +0 -0
  511. /package/dist/{data-structures → cjs/data-structures}/priority-queue/priority-queue.d.ts +0 -0
  512. /package/dist/{data-structures → cjs/data-structures}/priority-queue/priority-queue.js +0 -0
  513. /package/dist/{data-structures → cjs/data-structures}/queue/deque.d.ts +0 -0
  514. /package/dist/{data-structures → cjs/data-structures}/queue/deque.js +0 -0
  515. /package/dist/{data-structures → cjs/data-structures}/queue/index.d.ts +0 -0
  516. /package/dist/{data-structures → cjs/data-structures}/queue/index.js +0 -0
  517. /package/dist/{data-structures → cjs/data-structures}/queue/queue.d.ts +0 -0
  518. /package/dist/{data-structures → cjs/data-structures}/queue/queue.js +0 -0
  519. /package/dist/{data-structures → cjs/data-structures}/stack/index.d.ts +0 -0
  520. /package/dist/{data-structures → cjs/data-structures}/stack/index.js +0 -0
  521. /package/dist/{data-structures → cjs/data-structures}/stack/stack.d.ts +0 -0
  522. /package/dist/{data-structures → cjs/data-structures}/stack/stack.js +0 -0
  523. /package/dist/{data-structures → cjs/data-structures}/tree/index.d.ts +0 -0
  524. /package/dist/{data-structures → cjs/data-structures}/tree/index.js +0 -0
  525. /package/dist/{data-structures → cjs/data-structures}/tree/tree.d.ts +0 -0
  526. /package/dist/{data-structures → cjs/data-structures}/tree/tree.js +0 -0
  527. /package/dist/{data-structures → cjs/data-structures}/trie/index.d.ts +0 -0
  528. /package/dist/{data-structures → cjs/data-structures}/trie/index.js +0 -0
  529. /package/dist/{data-structures → cjs/data-structures}/trie/trie.d.ts +0 -0
  530. /package/dist/{data-structures → cjs/data-structures}/trie/trie.js +0 -0
  531. /package/dist/{index.d.ts → cjs/index.d.ts} +0 -0
  532. /package/dist/{index.js → cjs/index.js} +0 -0
  533. /package/dist/{interfaces → cjs/interfaces}/binary-tree.d.ts +0 -0
  534. /package/dist/{interfaces → cjs/interfaces}/binary-tree.js +0 -0
  535. /package/dist/{interfaces → cjs/interfaces}/doubly-linked-list.d.ts +0 -0
  536. /package/dist/{interfaces → cjs/interfaces}/doubly-linked-list.js +0 -0
  537. /package/dist/{interfaces → cjs/interfaces}/graph.d.ts +0 -0
  538. /package/dist/{interfaces → cjs/interfaces}/graph.js +0 -0
  539. /package/dist/{interfaces → cjs/interfaces}/heap.d.ts +0 -0
  540. /package/dist/{interfaces → cjs/interfaces}/heap.js +0 -0
  541. /package/dist/{interfaces → cjs/interfaces}/index.d.ts +0 -0
  542. /package/dist/{interfaces → cjs/interfaces}/index.js +0 -0
  543. /package/dist/{interfaces → cjs/interfaces}/navigator.d.ts +0 -0
  544. /package/dist/{interfaces → cjs/interfaces}/navigator.js +0 -0
  545. /package/dist/{interfaces → cjs/interfaces}/priority-queue.d.ts +0 -0
  546. /package/dist/{interfaces → cjs/interfaces}/priority-queue.js +0 -0
  547. /package/dist/{interfaces → cjs/interfaces}/segment-tree.d.ts +0 -0
  548. /package/dist/{interfaces → cjs/interfaces}/segment-tree.js +0 -0
  549. /package/dist/{interfaces → cjs/interfaces}/singly-linked-list.d.ts +0 -0
  550. /package/dist/{interfaces → cjs/interfaces}/singly-linked-list.js +0 -0
  551. /package/dist/{types → cjs/types}/data-structures/binary-tree/avl-tree.d.ts +0 -0
  552. /package/dist/{types → cjs/types}/data-structures/binary-tree/avl-tree.js +0 -0
  553. /package/dist/{types → cjs/types}/data-structures/binary-tree/binary-indexed-tree.d.ts +0 -0
  554. /package/dist/{types → cjs/types}/data-structures/binary-tree/binary-indexed-tree.js +0 -0
  555. /package/dist/{types → cjs/types}/data-structures/binary-tree/binary-tree.js +0 -0
  556. /package/dist/{types → cjs/types}/data-structures/binary-tree/bst.d.ts +0 -0
  557. /package/dist/{types → cjs/types}/data-structures/binary-tree/bst.js +0 -0
  558. /package/dist/{types → cjs/types}/data-structures/binary-tree/index.d.ts +0 -0
  559. /package/dist/{types → cjs/types}/data-structures/binary-tree/index.js +0 -0
  560. /package/dist/{types → cjs/types}/data-structures/binary-tree/rb-tree.d.ts +0 -0
  561. /package/dist/{types → cjs/types}/data-structures/binary-tree/rb-tree.js +0 -0
  562. /package/dist/{types → cjs/types}/data-structures/binary-tree/segment-tree.d.ts +0 -0
  563. /package/dist/{types → cjs/types}/data-structures/binary-tree/segment-tree.js +0 -0
  564. /package/dist/{types → cjs/types}/data-structures/binary-tree/tree-multiset.d.ts +0 -0
  565. /package/dist/{types → cjs/types}/data-structures/binary-tree/tree-multiset.js +0 -0
  566. /package/dist/{types → cjs/types}/data-structures/graph/abstract-graph.d.ts +0 -0
  567. /package/dist/{types → cjs/types}/data-structures/graph/abstract-graph.js +0 -0
  568. /package/dist/{types → cjs/types}/data-structures/graph/directed-graph.d.ts +0 -0
  569. /package/dist/{types → cjs/types}/data-structures/graph/directed-graph.js +0 -0
  570. /package/dist/{types → cjs/types}/data-structures/graph/index.d.ts +0 -0
  571. /package/dist/{types → cjs/types}/data-structures/graph/index.js +0 -0
  572. /package/dist/{types → cjs/types}/data-structures/graph/map-graph.d.ts +0 -0
  573. /package/dist/{types → cjs/types}/data-structures/graph/map-graph.js +0 -0
  574. /package/dist/{types → cjs/types}/data-structures/graph/undirected-graph.d.ts +0 -0
  575. /package/dist/{types → cjs/types}/data-structures/graph/undirected-graph.js +0 -0
  576. /package/dist/{types → cjs/types}/data-structures/hash/coordinate-map.d.ts +0 -0
  577. /package/dist/{types → cjs/types}/data-structures/hash/coordinate-map.js +0 -0
  578. /package/dist/{types → cjs/types}/data-structures/hash/coordinate-set.d.ts +0 -0
  579. /package/dist/{types → cjs/types}/data-structures/hash/coordinate-set.js +0 -0
  580. /package/dist/{types → cjs/types}/data-structures/hash/hash-map.d.ts +0 -0
  581. /package/dist/{types → cjs/types}/data-structures/hash/hash-map.js +0 -0
  582. /package/dist/{types → cjs/types}/data-structures/hash/hash-table.d.ts +0 -0
  583. /package/dist/{types → cjs/types}/data-structures/hash/hash-table.js +0 -0
  584. /package/dist/{types → cjs/types}/data-structures/hash/index.d.ts +0 -0
  585. /package/dist/{types → cjs/types}/data-structures/hash/index.js +0 -0
  586. /package/dist/{types → cjs/types}/data-structures/hash/tree-map.d.ts +0 -0
  587. /package/dist/{types → cjs/types}/data-structures/hash/tree-map.js +0 -0
  588. /package/dist/{types → cjs/types}/data-structures/hash/tree-set.d.ts +0 -0
  589. /package/dist/{types → cjs/types}/data-structures/hash/tree-set.js +0 -0
  590. /package/dist/{types → cjs/types}/data-structures/heap/heap.d.ts +0 -0
  591. /package/dist/{types → cjs/types}/data-structures/heap/heap.js +0 -0
  592. /package/dist/{types → cjs/types}/data-structures/heap/index.d.ts +0 -0
  593. /package/dist/{types → cjs/types}/data-structures/heap/index.js +0 -0
  594. /package/dist/{types → cjs/types}/data-structures/heap/max-heap.d.ts +0 -0
  595. /package/dist/{types → cjs/types}/data-structures/heap/max-heap.js +0 -0
  596. /package/dist/{types → cjs/types}/data-structures/heap/min-heap.d.ts +0 -0
  597. /package/dist/{types → cjs/types}/data-structures/heap/min-heap.js +0 -0
  598. /package/dist/{types → cjs/types}/data-structures/index.d.ts +0 -0
  599. /package/dist/{types → cjs/types}/data-structures/index.js +0 -0
  600. /package/dist/{types → cjs/types}/data-structures/linked-list/doubly-linked-list.d.ts +0 -0
  601. /package/dist/{types → cjs/types}/data-structures/linked-list/doubly-linked-list.js +0 -0
  602. /package/dist/{types → cjs/types}/data-structures/linked-list/index.d.ts +0 -0
  603. /package/dist/{types → cjs/types}/data-structures/linked-list/index.js +0 -0
  604. /package/dist/{types → cjs/types}/data-structures/linked-list/singly-linked-list.d.ts +0 -0
  605. /package/dist/{types → cjs/types}/data-structures/linked-list/singly-linked-list.js +0 -0
  606. /package/dist/{types → cjs/types}/data-structures/linked-list/skip-linked-list.d.ts +0 -0
  607. /package/dist/{types → cjs/types}/data-structures/linked-list/skip-linked-list.js +0 -0
  608. /package/dist/{types → cjs/types}/data-structures/matrix/index.d.ts +0 -0
  609. /package/dist/{types → cjs/types}/data-structures/matrix/index.js +0 -0
  610. /package/dist/{types → cjs/types}/data-structures/matrix/matrix.d.ts +0 -0
  611. /package/dist/{types → cjs/types}/data-structures/matrix/matrix.js +0 -0
  612. /package/dist/{types → cjs/types}/data-structures/matrix/matrix2d.d.ts +0 -0
  613. /package/dist/{types → cjs/types}/data-structures/matrix/matrix2d.js +0 -0
  614. /package/dist/{types → cjs/types}/data-structures/matrix/navigator.d.ts +0 -0
  615. /package/dist/{types → cjs/types}/data-structures/matrix/navigator.js +0 -0
  616. /package/dist/{types → cjs/types}/data-structures/matrix/vector2d.d.ts +0 -0
  617. /package/dist/{types → cjs/types}/data-structures/matrix/vector2d.js +0 -0
  618. /package/dist/{types → cjs/types}/data-structures/priority-queue/index.d.ts +0 -0
  619. /package/dist/{types → cjs/types}/data-structures/priority-queue/index.js +0 -0
  620. /package/dist/{types → cjs/types}/data-structures/priority-queue/max-priority-queue.d.ts +0 -0
  621. /package/dist/{types → cjs/types}/data-structures/priority-queue/max-priority-queue.js +0 -0
  622. /package/dist/{types → cjs/types}/data-structures/priority-queue/min-priority-queue.d.ts +0 -0
  623. /package/dist/{types → cjs/types}/data-structures/priority-queue/min-priority-queue.js +0 -0
  624. /package/dist/{types → cjs/types}/data-structures/priority-queue/priority-queue.d.ts +0 -0
  625. /package/dist/{types → cjs/types}/data-structures/priority-queue/priority-queue.js +0 -0
  626. /package/dist/{types → cjs/types}/data-structures/queue/deque.d.ts +0 -0
  627. /package/dist/{types → cjs/types}/data-structures/queue/deque.js +0 -0
  628. /package/dist/{types → cjs/types}/data-structures/queue/index.d.ts +0 -0
  629. /package/dist/{types → cjs/types}/data-structures/queue/index.js +0 -0
  630. /package/dist/{types → cjs/types}/data-structures/queue/queue.d.ts +0 -0
  631. /package/dist/{types → cjs/types}/data-structures/queue/queue.js +0 -0
  632. /package/dist/{types → cjs/types}/data-structures/stack/index.d.ts +0 -0
  633. /package/dist/{types → cjs/types}/data-structures/stack/index.js +0 -0
  634. /package/dist/{types → cjs/types}/data-structures/stack/stack.d.ts +0 -0
  635. /package/dist/{types → cjs/types}/data-structures/stack/stack.js +0 -0
  636. /package/dist/{types → cjs/types}/data-structures/tree/index.d.ts +0 -0
  637. /package/dist/{types → cjs/types}/data-structures/tree/index.js +0 -0
  638. /package/dist/{types → cjs/types}/data-structures/tree/tree.d.ts +0 -0
  639. /package/dist/{types → cjs/types}/data-structures/tree/tree.js +0 -0
  640. /package/dist/{types → cjs/types}/data-structures/trie/index.d.ts +0 -0
  641. /package/dist/{types → cjs/types}/data-structures/trie/index.js +0 -0
  642. /package/dist/{types → cjs/types}/data-structures/trie/trie.d.ts +0 -0
  643. /package/dist/{types → cjs/types}/data-structures/trie/trie.js +0 -0
  644. /package/dist/{types → cjs/types}/helpers.js +0 -0
  645. /package/dist/{types → cjs/types}/index.d.ts +0 -0
  646. /package/dist/{types → cjs/types}/index.js +0 -0
  647. /package/dist/{types → cjs/types}/utils/index.d.ts +0 -0
  648. /package/dist/{types → cjs/types}/utils/index.js +0 -0
  649. /package/dist/{types → cjs/types}/utils/utils.d.ts +0 -0
  650. /package/dist/{types → cjs/types}/utils/utils.js +0 -0
  651. /package/dist/{types → cjs/types}/utils/validate-type.d.ts +0 -0
  652. /package/dist/{types → cjs/types}/utils/validate-type.js +0 -0
  653. /package/dist/{utils → cjs/utils}/index.d.ts +0 -0
  654. /package/dist/{utils → cjs/utils}/index.js +0 -0
  655. /package/dist/{utils → cjs/utils}/utils.d.ts +0 -0
  656. /package/dist/{utils → cjs/utils}/utils.js +0 -0
  657. /package/{lib → dist/mjs}/data-structures/binary-tree/avl-tree.d.ts +0 -0
  658. /package/{lib → dist/mjs}/data-structures/binary-tree/binary-indexed-tree.d.ts +0 -0
  659. /package/{lib → dist/mjs}/data-structures/binary-tree/index.d.ts +0 -0
  660. /package/{lib → dist/mjs}/data-structures/binary-tree/rb-tree.d.ts +0 -0
  661. /package/{lib → dist/mjs}/data-structures/binary-tree/segment-tree.d.ts +0 -0
  662. /package/{lib → dist/mjs}/data-structures/binary-tree/tree-multiset.d.ts +0 -0
  663. /package/{lib → dist/mjs}/data-structures/graph/abstract-graph.d.ts +0 -0
  664. /package/{lib → dist/mjs}/data-structures/graph/directed-graph.d.ts +0 -0
  665. /package/{lib → dist/mjs}/data-structures/graph/index.d.ts +0 -0
  666. /package/{lib → dist/mjs}/data-structures/graph/map-graph.d.ts +0 -0
  667. /package/{lib → dist/mjs}/data-structures/graph/undirected-graph.d.ts +0 -0
  668. /package/{lib → dist/mjs}/data-structures/hash/coordinate-map.d.ts +0 -0
  669. /package/{lib → dist/mjs}/data-structures/hash/coordinate-set.d.ts +0 -0
  670. /package/{lib → dist/mjs}/data-structures/hash/hash-map.d.ts +0 -0
  671. /package/{lib → dist/mjs}/data-structures/hash/hash-table.d.ts +0 -0
  672. /package/{lib → dist/mjs}/data-structures/hash/index.d.ts +0 -0
  673. /package/{lib → dist/mjs}/data-structures/hash/tree-map.d.ts +0 -0
  674. /package/{lib → dist/mjs}/data-structures/hash/tree-set.d.ts +0 -0
  675. /package/{lib → dist/mjs}/data-structures/heap/heap.d.ts +0 -0
  676. /package/{lib → dist/mjs}/data-structures/heap/index.d.ts +0 -0
  677. /package/{lib → dist/mjs}/data-structures/heap/max-heap.d.ts +0 -0
  678. /package/{lib → dist/mjs}/data-structures/heap/min-heap.d.ts +0 -0
  679. /package/{lib → dist/mjs}/data-structures/index.d.ts +0 -0
  680. /package/{lib → dist/mjs}/data-structures/linked-list/doubly-linked-list.d.ts +0 -0
  681. /package/{lib → dist/mjs}/data-structures/linked-list/index.d.ts +0 -0
  682. /package/{lib → dist/mjs}/data-structures/linked-list/singly-linked-list.d.ts +0 -0
  683. /package/{lib → dist/mjs}/data-structures/linked-list/skip-linked-list.d.ts +0 -0
  684. /package/{lib → dist/mjs}/data-structures/matrix/index.d.ts +0 -0
  685. /package/{lib → dist/mjs}/data-structures/matrix/matrix.d.ts +0 -0
  686. /package/{lib → dist/mjs}/data-structures/matrix/matrix2d.d.ts +0 -0
  687. /package/{lib → dist/mjs}/data-structures/matrix/navigator.d.ts +0 -0
  688. /package/{lib → dist/mjs}/data-structures/matrix/vector2d.d.ts +0 -0
  689. /package/{lib → dist/mjs}/data-structures/priority-queue/index.d.ts +0 -0
  690. /package/{lib → dist/mjs}/data-structures/priority-queue/max-priority-queue.d.ts +0 -0
  691. /package/{lib → dist/mjs}/data-structures/priority-queue/min-priority-queue.d.ts +0 -0
  692. /package/{lib → dist/mjs}/data-structures/priority-queue/priority-queue.d.ts +0 -0
  693. /package/{lib → dist/mjs}/data-structures/queue/deque.d.ts +0 -0
  694. /package/{lib → dist/mjs}/data-structures/queue/index.d.ts +0 -0
  695. /package/{lib → dist/mjs}/data-structures/queue/queue.d.ts +0 -0
  696. /package/{lib → dist/mjs}/data-structures/stack/index.d.ts +0 -0
  697. /package/{lib → dist/mjs}/data-structures/stack/stack.d.ts +0 -0
  698. /package/{lib → dist/mjs}/data-structures/tree/index.d.ts +0 -0
  699. /package/{lib → dist/mjs}/data-structures/tree/tree.d.ts +0 -0
  700. /package/{lib → dist/mjs}/data-structures/trie/index.d.ts +0 -0
  701. /package/{lib → dist/mjs}/data-structures/trie/trie.d.ts +0 -0
  702. /package/{lib → dist/mjs}/index.d.ts +0 -0
  703. /package/{lib → dist/mjs}/interfaces/binary-tree.d.ts +0 -0
  704. /package/{lib → dist/mjs}/interfaces/doubly-linked-list.d.ts +0 -0
  705. /package/{lib → dist/mjs}/interfaces/graph.d.ts +0 -0
  706. /package/{lib → dist/mjs}/interfaces/heap.d.ts +0 -0
  707. /package/{lib → dist/mjs}/interfaces/index.d.ts +0 -0
  708. /package/{lib → dist/mjs}/interfaces/navigator.d.ts +0 -0
  709. /package/{lib → dist/mjs}/interfaces/priority-queue.d.ts +0 -0
  710. /package/{lib → dist/mjs}/interfaces/segment-tree.d.ts +0 -0
  711. /package/{lib → dist/mjs}/interfaces/singly-linked-list.d.ts +0 -0
  712. /package/{lib → dist/mjs}/types/data-structures/binary-tree/avl-tree.d.ts +0 -0
  713. /package/{lib → dist/mjs}/types/data-structures/binary-tree/binary-indexed-tree.d.ts +0 -0
  714. /package/{lib → dist/mjs}/types/data-structures/binary-tree/bst.d.ts +0 -0
  715. /package/{lib → dist/mjs}/types/data-structures/binary-tree/index.d.ts +0 -0
  716. /package/{lib → dist/mjs}/types/data-structures/binary-tree/rb-tree.d.ts +0 -0
  717. /package/{lib → dist/mjs}/types/data-structures/binary-tree/segment-tree.d.ts +0 -0
  718. /package/{lib → dist/mjs}/types/data-structures/binary-tree/tree-multiset.d.ts +0 -0
  719. /package/{lib → dist/mjs}/types/data-structures/graph/abstract-graph.d.ts +0 -0
  720. /package/{lib → dist/mjs}/types/data-structures/graph/directed-graph.d.ts +0 -0
  721. /package/{lib → dist/mjs}/types/data-structures/graph/index.d.ts +0 -0
  722. /package/{lib → dist/mjs}/types/data-structures/graph/map-graph.d.ts +0 -0
  723. /package/{lib → dist/mjs}/types/data-structures/graph/undirected-graph.d.ts +0 -0
  724. /package/{lib → dist/mjs}/types/data-structures/hash/coordinate-map.d.ts +0 -0
  725. /package/{lib → dist/mjs}/types/data-structures/hash/coordinate-set.d.ts +0 -0
  726. /package/{lib → dist/mjs}/types/data-structures/hash/hash-map.d.ts +0 -0
  727. /package/{lib → dist/mjs}/types/data-structures/hash/hash-table.d.ts +0 -0
  728. /package/{lib → dist/mjs}/types/data-structures/hash/index.d.ts +0 -0
  729. /package/{lib → dist/mjs}/types/data-structures/hash/tree-map.d.ts +0 -0
  730. /package/{lib → dist/mjs}/types/data-structures/hash/tree-set.d.ts +0 -0
  731. /package/{lib → dist/mjs}/types/data-structures/heap/heap.d.ts +0 -0
  732. /package/{lib → dist/mjs}/types/data-structures/heap/index.d.ts +0 -0
  733. /package/{lib → dist/mjs}/types/data-structures/heap/max-heap.d.ts +0 -0
  734. /package/{lib → dist/mjs}/types/data-structures/heap/min-heap.d.ts +0 -0
  735. /package/{lib → dist/mjs}/types/data-structures/index.d.ts +0 -0
  736. /package/{lib → dist/mjs}/types/data-structures/linked-list/doubly-linked-list.d.ts +0 -0
  737. /package/{lib → dist/mjs}/types/data-structures/linked-list/index.d.ts +0 -0
  738. /package/{lib → dist/mjs}/types/data-structures/linked-list/singly-linked-list.d.ts +0 -0
  739. /package/{lib → dist/mjs}/types/data-structures/linked-list/skip-linked-list.d.ts +0 -0
  740. /package/{lib → dist/mjs}/types/data-structures/matrix/index.d.ts +0 -0
  741. /package/{lib → dist/mjs}/types/data-structures/matrix/matrix.d.ts +0 -0
  742. /package/{lib → dist/mjs}/types/data-structures/matrix/matrix2d.d.ts +0 -0
  743. /package/{lib → dist/mjs}/types/data-structures/matrix/navigator.d.ts +0 -0
  744. /package/{lib → dist/mjs}/types/data-structures/matrix/vector2d.d.ts +0 -0
  745. /package/{lib → dist/mjs}/types/data-structures/priority-queue/index.d.ts +0 -0
  746. /package/{lib → dist/mjs}/types/data-structures/priority-queue/max-priority-queue.d.ts +0 -0
  747. /package/{lib → dist/mjs}/types/data-structures/priority-queue/min-priority-queue.d.ts +0 -0
  748. /package/{lib → dist/mjs}/types/data-structures/priority-queue/priority-queue.d.ts +0 -0
  749. /package/{lib → dist/mjs}/types/data-structures/queue/deque.d.ts +0 -0
  750. /package/{lib → dist/mjs}/types/data-structures/queue/index.d.ts +0 -0
  751. /package/{lib → dist/mjs}/types/data-structures/queue/queue.d.ts +0 -0
  752. /package/{lib → dist/mjs}/types/data-structures/stack/index.d.ts +0 -0
  753. /package/{lib → dist/mjs}/types/data-structures/stack/stack.d.ts +0 -0
  754. /package/{lib → dist/mjs}/types/data-structures/tree/index.d.ts +0 -0
  755. /package/{lib → dist/mjs}/types/data-structures/tree/tree.d.ts +0 -0
  756. /package/{lib → dist/mjs}/types/data-structures/trie/index.d.ts +0 -0
  757. /package/{lib → dist/mjs}/types/data-structures/trie/trie.d.ts +0 -0
  758. /package/{lib → dist/mjs}/types/index.d.ts +0 -0
  759. /package/{lib → dist/mjs}/types/utils/index.d.ts +0 -0
  760. /package/{lib → dist/mjs}/types/utils/utils.d.ts +0 -0
  761. /package/{lib → dist/mjs}/types/utils/validate-type.d.ts +0 -0
  762. /package/{lib → dist/mjs}/utils/index.d.ts +0 -0
  763. /package/{lib → dist/mjs}/utils/utils.d.ts +0 -0
package/package.json CHANGED
@@ -1,21 +1,23 @@
1
1
  {
2
2
  "name": "data-structure-typed",
3
- "version": "1.38.1",
3
+ "version": "1.38.3",
4
4
  "description": "Data Structures of Javascript & TypeScript. Binary Tree, BST, Graph, Heap, Priority Queue, Linked List, Queue, Deque, Stack, AVL Tree, Tree Multiset, Trie, Directed Graph, Undirected Graph, Singly Linked List, Doubly Linked List, Max Heap, Max Priority Queue, Min Heap, Min Priority Queue.",
5
- "main": "dist/index.js",
6
- "module": "lib/index.js",
7
- "types": "lib/index.d.ts",
8
- "source": "src/index.ts",
9
- "umd:main": "umd/bundle.min.js",
5
+ "main": "dist/cjs/index.js",
6
+ "module": "dist/mjs/index.js",
7
+ "types": "dist/mjs/index.d.ts",
8
+ "umd:main": "dist/umd/index.global.js",
10
9
  "exports": {
11
- "import": "./lib/index.js",
12
- "require": "./dist/index.js"
10
+ ".": {
11
+ "import": "./dist/mjs/index.js",
12
+ "require": "./dist/cjs/index.js",
13
+ "types": "./dist/mjs/index.d.ts"
14
+ }
13
15
  },
14
16
  "scripts": {
15
- "build": "npm run build:es6 && npm run build:commonjs && npm run build:umd && npm run build:docs",
16
- "build:es6": "rm -rf lib && tsc",
17
- "build:commonjs": "rm -rf dist && tsc --project tsconfig.prod.json",
18
- "build:umd": "webpack",
17
+ "build": "npm run build:mjs && npm run build:cjs && npm run build:umd && npm run build:docs",
18
+ "build:mjs": "rm -rf dist/mjs && tsc -p tsconfig.json",
19
+ "build:cjs": "rm -rf dist/cjs && tsc -p tsconfig-cjs.json",
20
+ "build:umd": "tsup",
19
21
  "build:docs": "typedoc --out docs ./src",
20
22
  "check": "tsc --noEmit",
21
23
  "lint:src": "eslint --fix 'src/**/*.{js,ts}'",
@@ -59,26 +61,25 @@
59
61
  "@typescript-eslint/eslint-plugin": "^6.7.4",
60
62
  "@typescript-eslint/parser": "^6.7.4",
61
63
  "auto-changelog": "^2.4.0",
62
- "avl-tree-typed": "^1.38.0",
64
+ "avl-tree-typed": "^1.38.2",
63
65
  "benchmark": "^2.1.4",
64
- "binary-tree-typed": "^1.38.0",
65
- "bst-typed": "^1.38.0",
66
+ "binary-tree-typed": "^1.38.2",
67
+ "bst-typed": "^1.38.2",
66
68
  "dependency-cruiser": "^14.1.0",
67
69
  "eslint": "^8.50.0",
68
70
  "eslint-config-prettier": "^9.0.0",
69
71
  "eslint-import-resolver-alias": "^1.1.2",
70
72
  "eslint-import-resolver-typescript": "^3.6.1",
71
73
  "eslint-plugin-import": "^2.28.1",
72
- "heap-typed": "^1.38.0",
74
+ "heap-typed": "^1.38.2",
73
75
  "istanbul-badges-readme": "^1.8.5",
74
76
  "jest": "^29.7.0",
75
77
  "prettier": "^3.0.3",
76
78
  "ts-jest": "^29.1.1",
77
79
  "ts-loader": "^9.4.4",
80
+ "tsup": "^7.2.0",
78
81
  "typedoc": "^0.25.1",
79
- "typescript": "^5.2.2",
80
- "webpack": "^5.88.2",
81
- "webpack-cli": "^5.1.4"
82
+ "typescript": "^5.2.2"
82
83
  },
83
84
  "keywords": [
84
85
  "data",
@@ -226,8 +227,5 @@
226
227
  "tarjan",
227
228
  "Tarjan",
228
229
  "Tarjan's"
229
- ],
230
- "dependencies": {
231
- "data-structure-typed": "^1.37.5"
232
- }
230
+ ]
233
231
  }
@@ -512,9 +512,9 @@ export class BinaryTree<N extends BinaryTreeNode<N['val'], N> = BinaryTreeNode>
512
512
  * traverse the binary tree. It can have two possible values:
513
513
  * @returns The function `getNodes` returns an array of nodes (`N[]`).
514
514
  */
515
- getNodes(
515
+ getNodes<C extends MapCallback<N> = MapCallback<N, BinaryTreeNodeKey>>(
516
516
  nodeProperty: BinaryTreeNodeKey | N,
517
- callback: MapCallback<N> = this._defaultCallbackByKey,
517
+ callback: C = this._defaultCallbackByKey as C,
518
518
  onlyOne = false,
519
519
  beginRoot: N | null = this.root,
520
520
  iterationType = this.iterationType
@@ -570,9 +570,9 @@ export class BinaryTree<N extends BinaryTreeNode<N['val'], N> = BinaryTreeNode>
570
570
  * performed when searching for nodes in the binary tree. It can have one of the following values:
571
571
  * @returns a boolean value.
572
572
  */
573
- has(
573
+ has<C extends MapCallback<N> = MapCallback<N, BinaryTreeNodeKey>>(
574
574
  nodeProperty: BinaryTreeNodeKey | N,
575
- callback: MapCallback<N> = this._defaultCallbackByKey,
575
+ callback: C = this._defaultCallbackByKey as C,
576
576
  beginRoot = this.root,
577
577
  iterationType = this.iterationType
578
578
  ): boolean {
@@ -595,9 +595,9 @@ export class BinaryTree<N extends BinaryTreeNode<N['val'], N> = BinaryTreeNode>
595
595
  * performed when searching for a node in the binary tree. It can have one of the following values:
596
596
  * @returns either the found node (of type N) or null if no node is found.
597
597
  */
598
- get(
598
+ get<C extends MapCallback<N> = MapCallback<N, BinaryTreeNodeKey>>(
599
599
  nodeProperty: BinaryTreeNodeKey | N,
600
- callback: MapCallback<N> = this._defaultCallbackByKey,
600
+ callback: C = this._defaultCallbackByKey as C,
601
601
  beginRoot = this.root,
602
602
  iterationType = this.iterationType
603
603
  ): N | null {
@@ -761,11 +761,11 @@ export class BinaryTree<N extends BinaryTreeNode<N['val'], N> = BinaryTreeNode>
761
761
  * performed on the binary tree. It can have two possible values:
762
762
  * @returns The function `subTreeTraverse` returns an array of `MapCallbackReturn<N>`.
763
763
  */
764
- subTreeTraverse(
765
- callback: MapCallback<N> = this._defaultCallbackByKey,
764
+ subTreeTraverse<C extends MapCallback<N> = MapCallback<N, BinaryTreeNodeKey>>(
765
+ callback: C = this._defaultCallbackByKey as C,
766
766
  beginRoot: N | BinaryTreeNodeKey | null = this.root,
767
767
  iterationType = this.iterationType
768
- ): MapCallbackReturn<N>[] {
768
+ ): ReturnType<C>[] {
769
769
  if (typeof beginRoot === 'number') beginRoot = this.get(beginRoot);
770
770
 
771
771
  const ans: MapCallbackReturn<N>[] = [];
@@ -808,12 +808,12 @@ export class BinaryTree<N extends BinaryTreeNode<N['val'], N> = BinaryTreeNode>
808
808
  * iteration used in the depth-first search algorithm. It can have two possible values:
809
809
  * @returns The function `dfs` returns an array of `MapCallbackReturn<N>` values.
810
810
  */
811
- dfs(
812
- callback: MapCallback<N> = this._defaultCallbackByKey,
811
+ dfs<C extends MapCallback<N> = MapCallback<N, BinaryTreeNodeKey>>(
812
+ callback: C = this._defaultCallbackByKey as C,
813
813
  pattern: DFSOrderPattern = 'in',
814
814
  beginRoot: N | null = this.root,
815
815
  iterationType: IterationType = IterationType.ITERATIVE
816
- ): MapCallbackReturn<N>[] {
816
+ ): ReturnType<C>[] {
817
817
  if (!beginRoot) return [];
818
818
  const ans: MapCallbackReturn<N>[] = [];
819
819
  if (iterationType === IterationType.RECURSIVE) {
@@ -896,12 +896,12 @@ export class BinaryTree<N extends BinaryTreeNode<N['val'], N> = BinaryTreeNode>
896
896
  * in the breadth-first search (BFS) algorithm. It can have two possible values:
897
897
  * @returns The function `bfs` returns an array of `BFSCallbackReturn<N>[]`.
898
898
  */
899
- bfs(
900
- callback: BFSCallback<N> = this._defaultCallbackByKey,
899
+ bfs<C extends BFSCallback<N> = BFSCallback<N, BinaryTreeNodeKey>>(
900
+ callback: C = this._defaultCallbackByKey as C,
901
901
  withLevel: boolean = false,
902
902
  beginRoot: N | null = this.root,
903
903
  iterationType = this.iterationType
904
- ): BFSCallbackReturn<N>[] {
904
+ ): ReturnType<C>[] {
905
905
  if (!beginRoot) return [];
906
906
 
907
907
  const ans: BFSCallbackReturn<N>[] = [];
@@ -964,11 +964,11 @@ export class BinaryTree<N extends BinaryTreeNode<N['val'], N> = BinaryTreeNode>
964
964
  * `beginRoot` is `null`, an empty array will be returned.
965
965
  * @returns The `morris` function returns an array of `MapCallbackReturn<N>` values.
966
966
  */
967
- morris(
968
- callback: MapCallback<N> = this._defaultCallbackByKey,
967
+ morris<C extends MapCallback<N> = MapCallback<N, BinaryTreeNodeKey>>(
968
+ callback: C = this._defaultCallbackByKey as C,
969
969
  pattern: DFSOrderPattern = 'in',
970
970
  beginRoot: N | null = this.root
971
- ): MapCallbackReturn<N>[] {
971
+ ): ReturnType<C>[] {
972
972
  if (beginRoot === null) return [];
973
973
  const ans: MapCallbackReturn<N>[] = [];
974
974
 
@@ -1078,7 +1078,7 @@ export class BinaryTree<N extends BinaryTreeNode<N['val'], N> = BinaryTreeNode>
1078
1078
  * This is because the purpose of the Morris algorithm is to save space rather than permanently alter the tree's shape.
1079
1079
  */
1080
1080
 
1081
- protected _defaultCallbackByKey: MapCallback<N> = node => node.key;
1081
+ protected _defaultCallbackByKey: (node: N) => number = node => node.key;
1082
1082
 
1083
1083
  /**
1084
1084
  * The function `_addTo` adds a new node to a binary tree if there is an available position.
@@ -238,9 +238,9 @@ export class BST<N extends BSTNode<N['val'], N> = BSTNode> extends BinaryTree<N>
238
238
  * @returns either the first node that matches the given nodeProperty and callback, or null if no
239
239
  * matching node is found.
240
240
  */
241
- override get(
241
+ override get<C extends MapCallback<N> = MapCallback<N, BinaryTreeNodeKey>>(
242
242
  nodeProperty: BinaryTreeNodeKey | N,
243
- callback: MapCallback<N> = this._defaultCallbackByKey,
243
+ callback: C = this._defaultCallbackByKey as C,
244
244
  beginRoot = this.root,
245
245
  iterationType = this.iterationType
246
246
  ): N | null {
@@ -289,9 +289,9 @@ export class BST<N extends BSTNode<N['val'], N> = BSTNode> extends BinaryTree<N>
289
289
  * traverse the binary tree. It can have one of the following values:
290
290
  * @returns an array of nodes (N[]).
291
291
  */
292
- override getNodes(
292
+ override getNodes<C extends MapCallback<N> = MapCallback<N, BinaryTreeNodeKey>>(
293
293
  nodeProperty: BinaryTreeNodeKey | N,
294
- callback: MapCallback<N> = this._defaultCallbackByKey,
294
+ callback: C = this._defaultCallbackByKey as C,
295
295
  onlyOne = false,
296
296
  beginRoot: N | null = this.root,
297
297
  iterationType = this.iterationType
@@ -363,12 +363,12 @@ export class BST<N extends BSTNode<N['val'], N> = BSTNode> extends BinaryTree<N>
363
363
  * done recursively or iteratively. It can have two possible values:
364
364
  * @returns The function `lesserOrGreaterTraverse` returns an array of `MapCallbackReturn<N>`.
365
365
  */
366
- lesserOrGreaterTraverse(
367
- callback: MapCallback<N> = this._defaultCallbackByKey,
366
+ lesserOrGreaterTraverse<C extends MapCallback<N> = MapCallback<N, BinaryTreeNodeKey>>(
367
+ callback: C = this._defaultCallbackByKey as C,
368
368
  lesserOrGreater: CP = CP.lt,
369
369
  targetNode: N | BinaryTreeNodeKey | null = this.root,
370
370
  iterationType = this.iterationType
371
- ): MapCallbackReturn<N> {
371
+ ): ReturnType<C>[] {
372
372
  if (typeof targetNode === 'number') targetNode = this.get(targetNode);
373
373
  const ans: MapCallbackReturn<N>[] = [];
374
374
  if (!targetNode) return ans;
@@ -24,7 +24,7 @@ export enum FamilyPosition {
24
24
 
25
25
  export type BinaryTreeNodeKey = number;
26
26
 
27
- export type BFSCallback<N> = (node: N, level?: number) => any;
27
+ export type BFSCallback<N, D = any> = (node: N, level?: number) => D;
28
28
 
29
29
  export type BFSCallbackReturn<N> = ReturnType<BFSCallback<N>>;
30
30
 
@@ -2,7 +2,7 @@ export type Comparator<T> = (a: T, b: T) => number;
2
2
 
3
3
  export type DFSOrderPattern = 'pre' | 'in' | 'post';
4
4
 
5
- export type MapCallback<N> = (node: N) => any;
5
+ export type MapCallback<N, D = any> = (node: N) => D;
6
6
 
7
7
  export type MapCallbackReturn<N> = ReturnType<MapCallback<N>>;
8
8
 
@@ -3,7 +3,7 @@
3
3
  <head>
4
4
  <meta charset='UTF-8'>
5
5
  <title>CDN Test</title>
6
- <script src='https://cdn.jsdelivr.net/npm/data-structure-typed/umd/bundle.min.js'></script>
6
+ <script src='https://cdn.jsdelivr.net/npm/data-structure-typed/dist/umd/index.global.js'></script>
7
7
  </head>
8
8
  <body>
9
9
  <div id='app'>
@@ -23,7 +23,7 @@
23
23
  $avlTreeSpan.innerText = 'AVLTree';
24
24
  $avlTree.append($avlTreeSpan);
25
25
  avlTree.add(1, 1);
26
- console.log(avlTree.BFS());
26
+ console.log(avlTree.bfs());
27
27
  $modules.append($avlTree);
28
28
 
29
29
 
@@ -40,8 +40,7 @@
40
40
 
41
41
  console.log(performance.now() - startTime);
42
42
 
43
- }
44
- catch (e) {
43
+ } catch (e) {
45
44
  console.error(e);
46
45
  }
47
46
 
@@ -1,4 +1,4 @@
1
- import {AVLTree, CP, AVLTreeNode} from '../../../../src';
1
+ import {AVLTree, AVLTreeNode, CP} from '../../../../src';
2
2
 
3
3
  describe('AVL Tree Test', () => {
4
4
  it('should perform various operations on a AVL Tree', () => {
@@ -38,8 +38,7 @@ describe('AVL Tree Test', () => {
38
38
  expect(dfs[dfs.length - 1].key).toBe(16);
39
39
 
40
40
  tree.perfectlyBalance();
41
- const bfs: AVLTreeNode<number>[] = [];
42
- tree.bfs(node => bfs.push(node));
41
+ const bfs = tree.bfs(node => node);
43
42
  expect(tree.isPerfectlyBalanced()).toBe(true);
44
43
  expect(bfs[0].key).toBe(8);
45
44
  expect(bfs[bfs.length - 1].key).toBe(16);
@@ -98,16 +97,33 @@ describe('AVL Tree Test', () => {
98
97
  expect(tree.getHeight()).toBe(1);
99
98
 
100
99
  expect(tree.isAVLBalanced()).toBe(true);
101
- const lastBFSIds = new Array<number>();
102
- tree.bfs(node => lastBFSIds.push(node.key));
100
+ const lastBFSIds = tree.bfs();
103
101
  expect(lastBFSIds[0]).toBe(12);
104
102
  expect(lastBFSIds[1]).toBe(2);
105
103
  expect(lastBFSIds[2]).toBe(16);
106
104
 
107
- const lastBFSNodes: AVLTreeNode<number>[] = [];
108
- tree.bfs(node => lastBFSNodes.push(node));
105
+ const lastBFSNodes = tree.bfs(node => node);
109
106
  expect(lastBFSNodes[0].key).toBe(12);
110
107
  expect(lastBFSNodes[1].key).toBe(2);
111
108
  expect(lastBFSNodes[2].key).toBe(16);
112
109
  });
113
110
  });
111
+
112
+ describe('AVLTree APIs test', () => {
113
+ const avl = new AVLTree<AVLTreeNode<{id: number; text: string}>>();
114
+ beforeEach(() => {
115
+ avl.clear();
116
+ });
117
+
118
+ it('add', () => {
119
+ avl.add(1);
120
+ const node2 = new AVLTreeNode(2);
121
+ avl.add(node2);
122
+ const node3 = new AVLTreeNode(3, {id: 3, text: 'text3'});
123
+ avl.add(node3);
124
+ avl.add(node3, {id: 3, text: 'text33'});
125
+
126
+ const bfsRes = avl.bfs(node => node.key, false);
127
+ expect(bfsRes[0]).toBe(2);
128
+ });
129
+ });
@@ -1,5 +1,5 @@
1
1
  import {BinaryIndexedTree} from '../../../../src';
2
- import {isDebugTest} from '../../../config';
2
+ // import {isDebugTest} from '../../../config';
3
3
 
4
4
  // const isDebug = isDebugTest;
5
5
 
@@ -251,6 +251,7 @@ describe('BinaryIndexedTree additional tests', () => {
251
251
  expect(bit.lowerBound(200)).toBe(10);
252
252
  });
253
253
  });
254
+
254
255
  function loopUpperBoundTests(bit: BinaryIndexedTree, values: number[]) {
255
256
  for (const value of values) {
256
257
  const index = bit.upperBound(value);
@@ -1,4 +1,4 @@
1
- import {BinaryTree, BinaryTreeNode} from '../../../../src';
1
+ import {AVLTree, AVLTreeNode, BinaryTree, BinaryTreeNode} from '../../../../src';
2
2
 
3
3
  describe('BinaryTreeNode', () => {
4
4
  it('should create an instance of BinaryTreeNode', () => {
@@ -194,3 +194,22 @@ describe('BinaryTree Morris Traversal', () => {
194
194
  expect(node1?.right).toBe(node3);
195
195
  });
196
196
  });
197
+
198
+ describe('BinaryTree APIs test', () => {
199
+ const avl = new AVLTree<AVLTreeNode<{id: number; text: string}>>();
200
+ beforeEach(() => {
201
+ avl.clear();
202
+ });
203
+
204
+ it('add', () => {
205
+ avl.add(1);
206
+ const node2 = new AVLTreeNode(2);
207
+ avl.add(node2);
208
+ const node3 = new AVLTreeNode(3, {id: 3, text: 'text3'});
209
+ avl.add(node3);
210
+ avl.add(node3, {id: 3, text: 'text33'});
211
+
212
+ const bfsRes = avl.bfs(node => node);
213
+ expect(bfsRes[0]?.key).toBe(2);
214
+ });
215
+ });
@@ -1,4 +1,4 @@
1
- import {HashTableNode, HashTable} from '../../../../src';
1
+ import {HashTable, HashTableNode} from '../../../../src';
2
2
 
3
3
  describe('HashNode', () => {
4
4
  it('should create a HashNode with key and value', () => {
@@ -1,4 +1,4 @@
1
- import {Character, NavigatorParams, Turning, Navigator} from '../../../../src';
1
+ import {Character, Navigator, NavigatorParams, Turning} from '../../../../src';
2
2
 
3
3
  const exampleMatrix: number[][] = [
4
4
  [0, 0, 0, 0],
@@ -1,4 +1,4 @@
1
- import {Deque, ArrayDeque, ObjectDeque} from '../../../../src';
1
+ import {ArrayDeque, Deque, ObjectDeque} from '../../../../src';
2
2
  import {bigO} from '../../../utils';
3
3
 
4
4
  describe('Deque Tests', () => {
@@ -1,4 +1,4 @@
1
- import {Queue, LinkedListQueue} from '../../../../src';
1
+ import {LinkedListQueue, Queue} from '../../../../src';
2
2
  import {bigO, magnitude} from '../../../utils';
3
3
 
4
4
  describe('Queue Operation Test', () => {
@@ -0,0 +1,27 @@
1
+ {
2
+ "compilerOptions": {
3
+ "allowJs": true,
4
+ "allowSyntheticDefaultImports": true,
5
+ "baseUrl": "src",
6
+ "declaration": true,
7
+ "esModuleInterop": true,
8
+ "inlineSourceMap": false,
9
+ "lib": ["esnext"],
10
+ "listEmittedFiles": false,
11
+ "listFiles": false,
12
+ "moduleResolution": "node",
13
+ "noFallthroughCasesInSwitch": true,
14
+ "pretty": true,
15
+ "resolveJsonModule": true,
16
+ "rootDir": "src",
17
+ "skipLibCheck": true,
18
+ "strict": true,
19
+ "traceResolution": false,
20
+ "types": ["node", "jest"]
21
+ },
22
+ "compileOnSave": false,
23
+ "exclude": ["node_modules", "dist"],
24
+ "include": [
25
+ "./src/**/*.ts", // Include your .ts files
26
+ ]
27
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "extends": "./tsconfig-base.json",
3
+ "compilerOptions": {
4
+ "module": "CommonJS",
5
+ "outDir": "dist/cjs",
6
+ "target": "ES2015",
7
+ "sourceMap": true
8
+ }
9
+ }
package/tsup.config.js ADDED
@@ -0,0 +1,11 @@
1
+ export default [{
2
+ entry: ['src/index.ts'],
3
+ format: ["iife"],
4
+ clean: true,
5
+ sourcemap: true,
6
+ minify: true,
7
+ outDir: 'dist/umd',
8
+ globalName: 'dataStructureTyped',
9
+ platform: "browser",
10
+ bundle: true
11
+ }];