data-structure-typed 1.41.4 → 1.41.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (773) hide show
  1. package/CHANGELOG.md +1 -1
  2. package/README.md +21 -302
  3. package/benchmark/report.html +18 -10
  4. package/benchmark/report.json +223 -117
  5. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/avl-tree.d.ts +1 -1
  6. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/avl-tree.js +2 -2
  7. package/dist/cjs/src/data-structures/binary-tree/avl-tree.js.map +1 -0
  8. package/dist/cjs/src/data-structures/binary-tree/binary-indexed-tree.js.map +1 -0
  9. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/binary-tree.d.ts +4 -3
  10. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/binary-tree.js +19 -18
  11. package/dist/cjs/src/data-structures/binary-tree/binary-tree.js.map +1 -0
  12. package/dist/{mjs → cjs/src}/data-structures/binary-tree/bst.d.ts +1 -20
  13. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/bst.js +5 -27
  14. package/dist/cjs/src/data-structures/binary-tree/bst.js.map +1 -0
  15. package/dist/cjs/src/data-structures/binary-tree/index.js.map +1 -0
  16. package/dist/cjs/src/data-structures/binary-tree/rb-tree.js.map +1 -0
  17. package/dist/cjs/src/data-structures/binary-tree/segment-tree.js.map +1 -0
  18. package/dist/{mjs → cjs/src}/data-structures/binary-tree/tree-multiset.d.ts +1 -1
  19. package/dist/cjs/{data-structures → src/data-structures}/binary-tree/tree-multiset.js +2 -2
  20. package/dist/cjs/src/data-structures/binary-tree/tree-multiset.js.map +1 -0
  21. package/dist/cjs/src/data-structures/graph/abstract-graph.js.map +1 -0
  22. package/dist/cjs/src/data-structures/graph/directed-graph.js.map +1 -0
  23. package/dist/cjs/src/data-structures/graph/index.js.map +1 -0
  24. package/dist/cjs/src/data-structures/graph/map-graph.js.map +1 -0
  25. package/dist/cjs/src/data-structures/graph/undirected-graph.js.map +1 -0
  26. package/dist/cjs/src/data-structures/hash/coordinate-map.js.map +1 -0
  27. package/dist/cjs/src/data-structures/hash/coordinate-set.js.map +1 -0
  28. package/dist/cjs/src/data-structures/hash/hash-map.js.map +1 -0
  29. package/dist/cjs/src/data-structures/hash/hash-table.js.map +1 -0
  30. package/dist/cjs/src/data-structures/hash/index.js.map +1 -0
  31. package/dist/cjs/src/data-structures/hash/tree-map.js.map +1 -0
  32. package/dist/cjs/src/data-structures/hash/tree-set.js.map +1 -0
  33. package/dist/cjs/src/data-structures/heap/heap.js.map +1 -0
  34. package/dist/cjs/src/data-structures/heap/index.js.map +1 -0
  35. package/dist/cjs/src/data-structures/heap/max-heap.js.map +1 -0
  36. package/dist/cjs/src/data-structures/heap/min-heap.js.map +1 -0
  37. package/dist/cjs/src/data-structures/index.js.map +1 -0
  38. package/dist/cjs/src/data-structures/linked-list/doubly-linked-list.js.map +1 -0
  39. package/dist/cjs/src/data-structures/linked-list/index.js.map +1 -0
  40. package/dist/cjs/src/data-structures/linked-list/singly-linked-list.js.map +1 -0
  41. package/dist/cjs/src/data-structures/linked-list/skip-linked-list.js.map +1 -0
  42. package/dist/cjs/src/data-structures/matrix/index.js.map +1 -0
  43. package/dist/cjs/src/data-structures/matrix/matrix.js.map +1 -0
  44. package/dist/cjs/src/data-structures/matrix/matrix2d.js.map +1 -0
  45. package/dist/cjs/src/data-structures/matrix/navigator.js.map +1 -0
  46. package/dist/cjs/src/data-structures/matrix/vector2d.js.map +1 -0
  47. package/dist/cjs/src/data-structures/priority-queue/index.js.map +1 -0
  48. package/dist/cjs/src/data-structures/priority-queue/max-priority-queue.js.map +1 -0
  49. package/dist/cjs/src/data-structures/priority-queue/min-priority-queue.js.map +1 -0
  50. package/dist/cjs/src/data-structures/priority-queue/priority-queue.js.map +1 -0
  51. package/dist/cjs/src/data-structures/queue/deque.js.map +1 -0
  52. package/dist/cjs/src/data-structures/queue/index.js.map +1 -0
  53. package/dist/cjs/src/data-structures/queue/queue.js.map +1 -0
  54. package/dist/cjs/src/data-structures/stack/index.js.map +1 -0
  55. package/dist/cjs/src/data-structures/stack/stack.js.map +1 -0
  56. package/dist/cjs/src/data-structures/tree/index.js.map +1 -0
  57. package/dist/cjs/src/data-structures/tree/tree.js.map +1 -0
  58. package/dist/cjs/src/data-structures/trie/index.js.map +1 -0
  59. package/dist/cjs/src/data-structures/trie/trie.js.map +1 -0
  60. package/dist/cjs/src/index.js.map +1 -0
  61. package/dist/cjs/src/interfaces/binary-tree.js.map +1 -0
  62. package/dist/cjs/src/interfaces/doubly-linked-list.js.map +1 -0
  63. package/dist/cjs/{interfaces → src/interfaces}/graph.js.map +1 -1
  64. package/dist/cjs/{interfaces → src/interfaces}/heap.js.map +1 -1
  65. package/dist/cjs/src/interfaces/index.js.map +1 -0
  66. package/dist/cjs/src/interfaces/navigator.js.map +1 -0
  67. package/dist/cjs/src/interfaces/priority-queue.js.map +1 -0
  68. package/dist/cjs/src/interfaces/segment-tree.js.map +1 -0
  69. package/dist/cjs/src/interfaces/singly-linked-list.js.map +1 -0
  70. package/dist/cjs/src/types/data-structures/binary-tree/avl-tree.js.map +1 -0
  71. package/dist/cjs/src/types/data-structures/binary-tree/binary-indexed-tree.js.map +1 -0
  72. package/dist/cjs/src/types/data-structures/binary-tree/binary-tree.js.map +1 -0
  73. package/dist/cjs/src/types/data-structures/binary-tree/bst.js.map +1 -0
  74. package/dist/cjs/src/types/data-structures/binary-tree/index.js.map +1 -0
  75. package/dist/cjs/src/types/data-structures/binary-tree/rb-tree.js.map +1 -0
  76. package/dist/cjs/src/types/data-structures/binary-tree/segment-tree.js.map +1 -0
  77. package/dist/cjs/src/types/data-structures/binary-tree/tree-multiset.js.map +1 -0
  78. package/dist/cjs/src/types/data-structures/graph/abstract-graph.js.map +1 -0
  79. package/dist/cjs/src/types/data-structures/graph/directed-graph.js.map +1 -0
  80. package/dist/cjs/src/types/data-structures/graph/index.js.map +1 -0
  81. package/dist/cjs/src/types/data-structures/graph/map-graph.js.map +1 -0
  82. package/dist/cjs/src/types/data-structures/graph/undirected-graph.js.map +1 -0
  83. package/dist/cjs/src/types/data-structures/hash/coordinate-map.js.map +1 -0
  84. package/dist/cjs/src/types/data-structures/hash/coordinate-set.js.map +1 -0
  85. package/dist/cjs/src/types/data-structures/hash/hash-map.js.map +1 -0
  86. package/dist/cjs/src/types/data-structures/hash/hash-table.js.map +1 -0
  87. package/dist/cjs/src/types/data-structures/hash/index.js.map +1 -0
  88. package/dist/cjs/src/types/data-structures/hash/tree-map.js.map +1 -0
  89. package/dist/cjs/src/types/data-structures/hash/tree-set.js.map +1 -0
  90. package/dist/cjs/src/types/data-structures/heap/heap.js.map +1 -0
  91. package/dist/cjs/src/types/data-structures/heap/index.js.map +1 -0
  92. package/dist/cjs/src/types/data-structures/heap/max-heap.js.map +1 -0
  93. package/dist/cjs/src/types/data-structures/heap/min-heap.js.map +1 -0
  94. package/dist/cjs/src/types/data-structures/index.js.map +1 -0
  95. package/dist/cjs/src/types/data-structures/linked-list/doubly-linked-list.js.map +1 -0
  96. package/dist/cjs/src/types/data-structures/linked-list/index.js.map +1 -0
  97. package/dist/cjs/src/types/data-structures/linked-list/singly-linked-list.js.map +1 -0
  98. package/dist/cjs/src/types/data-structures/linked-list/skip-linked-list.js.map +1 -0
  99. package/dist/cjs/src/types/data-structures/matrix/index.js.map +1 -0
  100. package/dist/cjs/src/types/data-structures/matrix/matrix.js.map +1 -0
  101. package/dist/cjs/src/types/data-structures/matrix/matrix2d.js.map +1 -0
  102. package/dist/cjs/src/types/data-structures/matrix/navigator.js.map +1 -0
  103. package/dist/cjs/src/types/data-structures/matrix/vector2d.js.map +1 -0
  104. package/dist/cjs/src/types/data-structures/priority-queue/index.js.map +1 -0
  105. package/dist/cjs/src/types/data-structures/priority-queue/max-priority-queue.js.map +1 -0
  106. package/dist/cjs/src/types/data-structures/priority-queue/min-priority-queue.js.map +1 -0
  107. package/dist/cjs/src/types/data-structures/priority-queue/priority-queue.js.map +1 -0
  108. package/dist/cjs/src/types/data-structures/queue/deque.js.map +1 -0
  109. package/dist/cjs/src/types/data-structures/queue/index.js.map +1 -0
  110. package/dist/cjs/src/types/data-structures/queue/queue.js.map +1 -0
  111. package/dist/cjs/src/types/data-structures/stack/index.js.map +1 -0
  112. package/dist/cjs/src/types/data-structures/stack/stack.js.map +1 -0
  113. package/dist/cjs/src/types/data-structures/tree/index.js.map +1 -0
  114. package/dist/cjs/src/types/data-structures/tree/tree.js.map +1 -0
  115. package/dist/cjs/src/types/data-structures/trie/index.js.map +1 -0
  116. package/dist/cjs/src/types/data-structures/trie/trie.js.map +1 -0
  117. package/dist/cjs/src/types/helpers.js.map +1 -0
  118. package/dist/cjs/src/types/index.js.map +1 -0
  119. package/dist/cjs/src/types/utils/index.js.map +1 -0
  120. package/dist/cjs/{types → src/types}/utils/utils.js.map +1 -1
  121. package/dist/cjs/src/types/utils/validate-type.js.map +1 -0
  122. package/dist/cjs/src/utils/index.js.map +1 -0
  123. package/dist/cjs/src/utils/utils.js.map +1 -0
  124. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/avl-tree.d.ts +1 -1
  125. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/avl-tree.js +2 -2
  126. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/binary-tree.d.ts +4 -3
  127. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/binary-tree.js +19 -18
  128. package/dist/{cjs → mjs/src}/data-structures/binary-tree/bst.d.ts +1 -20
  129. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/bst.js +5 -26
  130. package/dist/{cjs → mjs/src}/data-structures/binary-tree/tree-multiset.d.ts +1 -1
  131. package/dist/mjs/{data-structures → src/data-structures}/binary-tree/tree-multiset.js +2 -2
  132. package/dist/umd/data-structure-typed.min.js +1 -1
  133. package/dist/umd/data-structure-typed.min.js.map +1 -1
  134. package/package.json +11 -8
  135. package/src/data-structures/binary-tree/avl-tree.ts +2 -2
  136. package/src/data-structures/binary-tree/binary-tree.ts +20 -18
  137. package/src/data-structures/binary-tree/bst.ts +6 -33
  138. package/src/data-structures/binary-tree/tree-multiset.ts +2 -2
  139. package/tsconfig-base.json +20 -24
  140. package/tsconfig-cjs.json +5 -1
  141. package/tsconfig-mjs.json +12 -0
  142. package/dist/cjs/data-structures/binary-tree/avl-tree.js.map +0 -1
  143. package/dist/cjs/data-structures/binary-tree/binary-indexed-tree.js.map +0 -1
  144. package/dist/cjs/data-structures/binary-tree/binary-tree.js.map +0 -1
  145. package/dist/cjs/data-structures/binary-tree/bst.js.map +0 -1
  146. package/dist/cjs/data-structures/binary-tree/index.js.map +0 -1
  147. package/dist/cjs/data-structures/binary-tree/rb-tree.js.map +0 -1
  148. package/dist/cjs/data-structures/binary-tree/segment-tree.js.map +0 -1
  149. package/dist/cjs/data-structures/binary-tree/tree-multiset.js.map +0 -1
  150. package/dist/cjs/data-structures/graph/abstract-graph.js.map +0 -1
  151. package/dist/cjs/data-structures/graph/directed-graph.js.map +0 -1
  152. package/dist/cjs/data-structures/graph/index.js.map +0 -1
  153. package/dist/cjs/data-structures/graph/map-graph.js.map +0 -1
  154. package/dist/cjs/data-structures/graph/undirected-graph.js.map +0 -1
  155. package/dist/cjs/data-structures/hash/coordinate-map.js.map +0 -1
  156. package/dist/cjs/data-structures/hash/coordinate-set.js.map +0 -1
  157. package/dist/cjs/data-structures/hash/hash-map.js.map +0 -1
  158. package/dist/cjs/data-structures/hash/hash-table.js.map +0 -1
  159. package/dist/cjs/data-structures/hash/index.js.map +0 -1
  160. package/dist/cjs/data-structures/hash/tree-map.js.map +0 -1
  161. package/dist/cjs/data-structures/hash/tree-set.js.map +0 -1
  162. package/dist/cjs/data-structures/heap/heap.js.map +0 -1
  163. package/dist/cjs/data-structures/heap/index.js.map +0 -1
  164. package/dist/cjs/data-structures/heap/max-heap.js.map +0 -1
  165. package/dist/cjs/data-structures/heap/min-heap.js.map +0 -1
  166. package/dist/cjs/data-structures/index.js.map +0 -1
  167. package/dist/cjs/data-structures/linked-list/doubly-linked-list.js.map +0 -1
  168. package/dist/cjs/data-structures/linked-list/index.js.map +0 -1
  169. package/dist/cjs/data-structures/linked-list/singly-linked-list.js.map +0 -1
  170. package/dist/cjs/data-structures/linked-list/skip-linked-list.js.map +0 -1
  171. package/dist/cjs/data-structures/matrix/index.js.map +0 -1
  172. package/dist/cjs/data-structures/matrix/matrix.js.map +0 -1
  173. package/dist/cjs/data-structures/matrix/matrix2d.js.map +0 -1
  174. package/dist/cjs/data-structures/matrix/navigator.js.map +0 -1
  175. package/dist/cjs/data-structures/matrix/vector2d.js.map +0 -1
  176. package/dist/cjs/data-structures/priority-queue/index.js.map +0 -1
  177. package/dist/cjs/data-structures/priority-queue/max-priority-queue.js.map +0 -1
  178. package/dist/cjs/data-structures/priority-queue/min-priority-queue.js.map +0 -1
  179. package/dist/cjs/data-structures/priority-queue/priority-queue.js.map +0 -1
  180. package/dist/cjs/data-structures/queue/deque.js.map +0 -1
  181. package/dist/cjs/data-structures/queue/index.js.map +0 -1
  182. package/dist/cjs/data-structures/queue/queue.js.map +0 -1
  183. package/dist/cjs/data-structures/stack/index.js.map +0 -1
  184. package/dist/cjs/data-structures/stack/stack.js.map +0 -1
  185. package/dist/cjs/data-structures/tree/index.js.map +0 -1
  186. package/dist/cjs/data-structures/tree/tree.js.map +0 -1
  187. package/dist/cjs/data-structures/trie/index.js.map +0 -1
  188. package/dist/cjs/data-structures/trie/trie.js.map +0 -1
  189. package/dist/cjs/index.js.map +0 -1
  190. package/dist/cjs/interfaces/binary-tree.js.map +0 -1
  191. package/dist/cjs/interfaces/doubly-linked-list.js.map +0 -1
  192. package/dist/cjs/interfaces/index.js.map +0 -1
  193. package/dist/cjs/interfaces/navigator.js.map +0 -1
  194. package/dist/cjs/interfaces/priority-queue.js.map +0 -1
  195. package/dist/cjs/interfaces/segment-tree.js.map +0 -1
  196. package/dist/cjs/interfaces/singly-linked-list.js.map +0 -1
  197. package/dist/cjs/types/data-structures/binary-tree/avl-tree.js.map +0 -1
  198. package/dist/cjs/types/data-structures/binary-tree/binary-indexed-tree.js.map +0 -1
  199. package/dist/cjs/types/data-structures/binary-tree/binary-tree.js.map +0 -1
  200. package/dist/cjs/types/data-structures/binary-tree/bst.js.map +0 -1
  201. package/dist/cjs/types/data-structures/binary-tree/index.js.map +0 -1
  202. package/dist/cjs/types/data-structures/binary-tree/rb-tree.js.map +0 -1
  203. package/dist/cjs/types/data-structures/binary-tree/segment-tree.js.map +0 -1
  204. package/dist/cjs/types/data-structures/binary-tree/tree-multiset.js.map +0 -1
  205. package/dist/cjs/types/data-structures/graph/abstract-graph.js.map +0 -1
  206. package/dist/cjs/types/data-structures/graph/directed-graph.js.map +0 -1
  207. package/dist/cjs/types/data-structures/graph/index.js.map +0 -1
  208. package/dist/cjs/types/data-structures/graph/map-graph.js.map +0 -1
  209. package/dist/cjs/types/data-structures/graph/undirected-graph.js.map +0 -1
  210. package/dist/cjs/types/data-structures/hash/coordinate-map.js.map +0 -1
  211. package/dist/cjs/types/data-structures/hash/coordinate-set.js.map +0 -1
  212. package/dist/cjs/types/data-structures/hash/hash-map.js.map +0 -1
  213. package/dist/cjs/types/data-structures/hash/hash-table.js.map +0 -1
  214. package/dist/cjs/types/data-structures/hash/index.js.map +0 -1
  215. package/dist/cjs/types/data-structures/hash/tree-map.js.map +0 -1
  216. package/dist/cjs/types/data-structures/hash/tree-set.js.map +0 -1
  217. package/dist/cjs/types/data-structures/heap/heap.js.map +0 -1
  218. package/dist/cjs/types/data-structures/heap/index.js.map +0 -1
  219. package/dist/cjs/types/data-structures/heap/max-heap.js.map +0 -1
  220. package/dist/cjs/types/data-structures/heap/min-heap.js.map +0 -1
  221. package/dist/cjs/types/data-structures/index.js.map +0 -1
  222. package/dist/cjs/types/data-structures/linked-list/doubly-linked-list.js.map +0 -1
  223. package/dist/cjs/types/data-structures/linked-list/index.js.map +0 -1
  224. package/dist/cjs/types/data-structures/linked-list/singly-linked-list.js.map +0 -1
  225. package/dist/cjs/types/data-structures/linked-list/skip-linked-list.js.map +0 -1
  226. package/dist/cjs/types/data-structures/matrix/index.js.map +0 -1
  227. package/dist/cjs/types/data-structures/matrix/matrix.js.map +0 -1
  228. package/dist/cjs/types/data-structures/matrix/matrix2d.js.map +0 -1
  229. package/dist/cjs/types/data-structures/matrix/navigator.js.map +0 -1
  230. package/dist/cjs/types/data-structures/matrix/vector2d.js.map +0 -1
  231. package/dist/cjs/types/data-structures/priority-queue/index.js.map +0 -1
  232. package/dist/cjs/types/data-structures/priority-queue/max-priority-queue.js.map +0 -1
  233. package/dist/cjs/types/data-structures/priority-queue/min-priority-queue.js.map +0 -1
  234. package/dist/cjs/types/data-structures/priority-queue/priority-queue.js.map +0 -1
  235. package/dist/cjs/types/data-structures/queue/deque.js.map +0 -1
  236. package/dist/cjs/types/data-structures/queue/index.js.map +0 -1
  237. package/dist/cjs/types/data-structures/queue/queue.js.map +0 -1
  238. package/dist/cjs/types/data-structures/stack/index.js.map +0 -1
  239. package/dist/cjs/types/data-structures/stack/stack.js.map +0 -1
  240. package/dist/cjs/types/data-structures/tree/index.js.map +0 -1
  241. package/dist/cjs/types/data-structures/tree/tree.js.map +0 -1
  242. package/dist/cjs/types/data-structures/trie/index.js.map +0 -1
  243. package/dist/cjs/types/data-structures/trie/trie.js.map +0 -1
  244. package/dist/cjs/types/helpers.js.map +0 -1
  245. package/dist/cjs/types/index.js.map +0 -1
  246. package/dist/cjs/types/utils/index.js.map +0 -1
  247. package/dist/cjs/types/utils/validate-type.js.map +0 -1
  248. package/dist/cjs/utils/index.js.map +0 -1
  249. package/dist/cjs/utils/utils.js.map +0 -1
  250. package/test/config.ts +0 -1
  251. package/test/integration/avl-tree.test.ts +0 -110
  252. package/test/integration/bst.test.ts +0 -385
  253. package/test/integration/heap.test.js +0 -16
  254. package/test/integration/index.html +0 -51
  255. package/test/performance/data-structures/binary-tree/avl-tree.test.ts +0 -24
  256. package/test/performance/data-structures/binary-tree/binary-index-tree.test.ts +0 -0
  257. package/test/performance/data-structures/binary-tree/binary-tree.test.ts +0 -25
  258. package/test/performance/data-structures/binary-tree/bst.test.ts +0 -24
  259. package/test/performance/data-structures/binary-tree/overall.test.ts +0 -0
  260. package/test/performance/data-structures/binary-tree/rb-tree.test.ts +0 -0
  261. package/test/performance/data-structures/binary-tree/segment-tree.test.ts +0 -0
  262. package/test/performance/data-structures/binary-tree/tree-multiset.test.ts +0 -0
  263. package/test/performance/data-structures/graph/abstract-graph.test.ts +0 -0
  264. package/test/performance/data-structures/graph/directed-graph.test.ts +0 -0
  265. package/test/performance/data-structures/graph/map-graph.test.ts +0 -0
  266. package/test/performance/data-structures/graph/overall.test.ts +0 -0
  267. package/test/performance/data-structures/graph/undirected-graph.test.ts +0 -0
  268. package/test/performance/data-structures/hash/coordinate-map.test.ts +0 -0
  269. package/test/performance/data-structures/hash/coordinate-set.test.ts +0 -0
  270. package/test/performance/data-structures/hash/hash-map.test.ts +0 -0
  271. package/test/performance/data-structures/hash/hash-table.test.ts +0 -0
  272. package/test/performance/data-structures/heap/heap.test.ts +0 -30
  273. package/test/performance/data-structures/heap/max-heap.test.ts +0 -0
  274. package/test/performance/data-structures/heap/min-heap.test.ts +0 -0
  275. package/test/performance/data-structures/linked-list/doubly-linked-list.test.ts +0 -40
  276. package/test/performance/data-structures/linked-list/linked-list.test.ts +0 -0
  277. package/test/performance/data-structures/linked-list/singly-linked-list.test.ts +0 -34
  278. package/test/performance/data-structures/linked-list/skip-linked-list.test.ts +0 -0
  279. package/test/performance/data-structures/linked-list/skip-list.test.ts +0 -0
  280. package/test/performance/data-structures/matrix/matrix.test.ts +0 -0
  281. package/test/performance/data-structures/matrix/matrix2d.test.ts +0 -0
  282. package/test/performance/data-structures/matrix/navigator.test.ts +0 -0
  283. package/test/performance/data-structures/matrix/vector2d.test.ts +0 -0
  284. package/test/performance/data-structures/priority-queue/max-priority-queue.test.ts +0 -19
  285. package/test/performance/data-structures/priority-queue/min-priority-queue.test.ts +0 -0
  286. package/test/performance/data-structures/priority-queue/priority-queue.test.ts +0 -0
  287. package/test/performance/data-structures/queue/deque.test.ts +0 -21
  288. package/test/performance/data-structures/queue/queue.test.ts +0 -25
  289. package/test/performance/data-structures/stack/stack.test.ts +0 -0
  290. package/test/performance/data-structures/tree/tree.test.ts +0 -0
  291. package/test/performance/data-structures/trie/trie.test.ts +0 -0
  292. package/test/performance/reportor.ts +0 -174
  293. package/test/performance/types/index.ts +0 -1
  294. package/test/performance/types/reportor.ts +0 -3
  295. package/test/types/index.ts +0 -1
  296. package/test/types/utils/big-o.ts +0 -1
  297. package/test/types/utils/index.ts +0 -2
  298. package/test/types/utils/json2html.ts +0 -1
  299. package/test/unit/data-structures/binary-tree/avl-tree.test.ts +0 -269
  300. package/test/unit/data-structures/binary-tree/binary-index-tree.test.ts +0 -320
  301. package/test/unit/data-structures/binary-tree/binary-tree.test.ts +0 -486
  302. package/test/unit/data-structures/binary-tree/bst.test.ts +0 -840
  303. package/test/unit/data-structures/binary-tree/overall.test.ts +0 -66
  304. package/test/unit/data-structures/binary-tree/rb-tree.test.ts +0 -435
  305. package/test/unit/data-structures/binary-tree/segment-tree.test.ts +0 -50
  306. package/test/unit/data-structures/binary-tree/tree-multiset.test.ts +0 -542
  307. package/test/unit/data-structures/graph/abstract-graph.test.ts +0 -100
  308. package/test/unit/data-structures/graph/directed-graph.test.ts +0 -564
  309. package/test/unit/data-structures/graph/map-graph.test.ts +0 -126
  310. package/test/unit/data-structures/graph/overall.test.ts +0 -49
  311. package/test/unit/data-structures/graph/undirected-graph.test.ts +0 -149
  312. package/test/unit/data-structures/hash/coordinate-map.test.ts +0 -74
  313. package/test/unit/data-structures/hash/coordinate-set.test.ts +0 -66
  314. package/test/unit/data-structures/hash/hash-map.test.ts +0 -103
  315. package/test/unit/data-structures/hash/hash-table.test.ts +0 -186
  316. package/test/unit/data-structures/heap/heap.test.ts +0 -253
  317. package/test/unit/data-structures/heap/max-heap.test.ts +0 -52
  318. package/test/unit/data-structures/heap/min-heap.test.ts +0 -52
  319. package/test/unit/data-structures/linked-list/doubly-linked-list.test.ts +0 -400
  320. package/test/unit/data-structures/linked-list/linked-list.test.ts +0 -8
  321. package/test/unit/data-structures/linked-list/singly-linked-list.test.ts +0 -474
  322. package/test/unit/data-structures/linked-list/skip-linked-list.test.ts +0 -13
  323. package/test/unit/data-structures/linked-list/skip-list.test.ts +0 -86
  324. package/test/unit/data-structures/matrix/matrix.test.ts +0 -54
  325. package/test/unit/data-structures/matrix/matrix2d.test.ts +0 -345
  326. package/test/unit/data-structures/matrix/navigator.test.ts +0 -244
  327. package/test/unit/data-structures/matrix/vector2d.test.ts +0 -171
  328. package/test/unit/data-structures/priority-queue/max-priority-queue.test.ts +0 -73
  329. package/test/unit/data-structures/priority-queue/min-priority-queue.test.ts +0 -63
  330. package/test/unit/data-structures/priority-queue/priority-queue.test.ts +0 -53
  331. package/test/unit/data-structures/queue/deque.test.ts +0 -410
  332. package/test/unit/data-structures/queue/queue.test.ts +0 -207
  333. package/test/unit/data-structures/stack/stack.test.ts +0 -67
  334. package/test/unit/data-structures/tree/tree.test.ts +0 -39
  335. package/test/unit/data-structures/trie/trie.test.ts +0 -825
  336. package/test/utils/array.ts +0 -5
  337. package/test/utils/big-o.ts +0 -201
  338. package/test/utils/console.ts +0 -30
  339. package/test/utils/index.ts +0 -6
  340. package/test/utils/is.ts +0 -56
  341. package/test/utils/json2html.ts +0 -322
  342. package/test/utils/number.ts +0 -13
  343. package/umd/bundle.min.js +0 -3
  344. package/umd/bundle.min.js.LICENSE.txt +0 -28
  345. package/umd/bundle.min.js.map +0 -1
  346. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/binary-indexed-tree.d.ts +0 -0
  347. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/binary-indexed-tree.js +0 -0
  348. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/index.d.ts +0 -0
  349. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/index.js +0 -0
  350. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/rb-tree.d.ts +0 -0
  351. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/rb-tree.js +0 -0
  352. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/segment-tree.d.ts +0 -0
  353. /package/dist/cjs/{data-structures → src/data-structures}/binary-tree/segment-tree.js +0 -0
  354. /package/dist/cjs/{data-structures → src/data-structures}/graph/abstract-graph.d.ts +0 -0
  355. /package/dist/cjs/{data-structures → src/data-structures}/graph/abstract-graph.js +0 -0
  356. /package/dist/cjs/{data-structures → src/data-structures}/graph/directed-graph.d.ts +0 -0
  357. /package/dist/cjs/{data-structures → src/data-structures}/graph/directed-graph.js +0 -0
  358. /package/dist/cjs/{data-structures → src/data-structures}/graph/index.d.ts +0 -0
  359. /package/dist/cjs/{data-structures → src/data-structures}/graph/index.js +0 -0
  360. /package/dist/cjs/{data-structures → src/data-structures}/graph/map-graph.d.ts +0 -0
  361. /package/dist/cjs/{data-structures → src/data-structures}/graph/map-graph.js +0 -0
  362. /package/dist/cjs/{data-structures → src/data-structures}/graph/undirected-graph.d.ts +0 -0
  363. /package/dist/cjs/{data-structures → src/data-structures}/graph/undirected-graph.js +0 -0
  364. /package/dist/cjs/{data-structures → src/data-structures}/hash/coordinate-map.d.ts +0 -0
  365. /package/dist/cjs/{data-structures → src/data-structures}/hash/coordinate-map.js +0 -0
  366. /package/dist/cjs/{data-structures → src/data-structures}/hash/coordinate-set.d.ts +0 -0
  367. /package/dist/cjs/{data-structures → src/data-structures}/hash/coordinate-set.js +0 -0
  368. /package/dist/cjs/{data-structures → src/data-structures}/hash/hash-map.d.ts +0 -0
  369. /package/dist/cjs/{data-structures → src/data-structures}/hash/hash-map.js +0 -0
  370. /package/dist/cjs/{data-structures → src/data-structures}/hash/hash-table.d.ts +0 -0
  371. /package/dist/cjs/{data-structures → src/data-structures}/hash/hash-table.js +0 -0
  372. /package/dist/cjs/{data-structures → src/data-structures}/hash/index.d.ts +0 -0
  373. /package/dist/cjs/{data-structures → src/data-structures}/hash/index.js +0 -0
  374. /package/dist/cjs/{data-structures → src/data-structures}/hash/tree-map.d.ts +0 -0
  375. /package/dist/cjs/{data-structures → src/data-structures}/hash/tree-map.js +0 -0
  376. /package/dist/cjs/{data-structures → src/data-structures}/hash/tree-set.d.ts +0 -0
  377. /package/dist/cjs/{data-structures → src/data-structures}/hash/tree-set.js +0 -0
  378. /package/dist/cjs/{data-structures → src/data-structures}/heap/heap.d.ts +0 -0
  379. /package/dist/cjs/{data-structures → src/data-structures}/heap/heap.js +0 -0
  380. /package/dist/cjs/{data-structures → src/data-structures}/heap/index.d.ts +0 -0
  381. /package/dist/cjs/{data-structures → src/data-structures}/heap/index.js +0 -0
  382. /package/dist/cjs/{data-structures → src/data-structures}/heap/max-heap.d.ts +0 -0
  383. /package/dist/cjs/{data-structures → src/data-structures}/heap/max-heap.js +0 -0
  384. /package/dist/cjs/{data-structures → src/data-structures}/heap/min-heap.d.ts +0 -0
  385. /package/dist/cjs/{data-structures → src/data-structures}/heap/min-heap.js +0 -0
  386. /package/dist/cjs/{data-structures → src/data-structures}/index.d.ts +0 -0
  387. /package/dist/cjs/{data-structures → src/data-structures}/index.js +0 -0
  388. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/doubly-linked-list.d.ts +0 -0
  389. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/doubly-linked-list.js +0 -0
  390. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/index.d.ts +0 -0
  391. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/index.js +0 -0
  392. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/singly-linked-list.d.ts +0 -0
  393. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/singly-linked-list.js +0 -0
  394. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/skip-linked-list.d.ts +0 -0
  395. /package/dist/cjs/{data-structures → src/data-structures}/linked-list/skip-linked-list.js +0 -0
  396. /package/dist/cjs/{data-structures → src/data-structures}/matrix/index.d.ts +0 -0
  397. /package/dist/cjs/{data-structures → src/data-structures}/matrix/index.js +0 -0
  398. /package/dist/cjs/{data-structures → src/data-structures}/matrix/matrix.d.ts +0 -0
  399. /package/dist/cjs/{data-structures → src/data-structures}/matrix/matrix.js +0 -0
  400. /package/dist/cjs/{data-structures → src/data-structures}/matrix/matrix2d.d.ts +0 -0
  401. /package/dist/cjs/{data-structures → src/data-structures}/matrix/matrix2d.js +0 -0
  402. /package/dist/cjs/{data-structures → src/data-structures}/matrix/navigator.d.ts +0 -0
  403. /package/dist/cjs/{data-structures → src/data-structures}/matrix/navigator.js +0 -0
  404. /package/dist/cjs/{data-structures → src/data-structures}/matrix/vector2d.d.ts +0 -0
  405. /package/dist/cjs/{data-structures → src/data-structures}/matrix/vector2d.js +0 -0
  406. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/index.d.ts +0 -0
  407. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/index.js +0 -0
  408. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/max-priority-queue.d.ts +0 -0
  409. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/max-priority-queue.js +0 -0
  410. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/min-priority-queue.d.ts +0 -0
  411. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/min-priority-queue.js +0 -0
  412. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/priority-queue.d.ts +0 -0
  413. /package/dist/cjs/{data-structures → src/data-structures}/priority-queue/priority-queue.js +0 -0
  414. /package/dist/cjs/{data-structures → src/data-structures}/queue/deque.d.ts +0 -0
  415. /package/dist/cjs/{data-structures → src/data-structures}/queue/deque.js +0 -0
  416. /package/dist/cjs/{data-structures → src/data-structures}/queue/index.d.ts +0 -0
  417. /package/dist/cjs/{data-structures → src/data-structures}/queue/index.js +0 -0
  418. /package/dist/cjs/{data-structures → src/data-structures}/queue/queue.d.ts +0 -0
  419. /package/dist/cjs/{data-structures → src/data-structures}/queue/queue.js +0 -0
  420. /package/dist/cjs/{data-structures → src/data-structures}/stack/index.d.ts +0 -0
  421. /package/dist/cjs/{data-structures → src/data-structures}/stack/index.js +0 -0
  422. /package/dist/cjs/{data-structures → src/data-structures}/stack/stack.d.ts +0 -0
  423. /package/dist/cjs/{data-structures → src/data-structures}/stack/stack.js +0 -0
  424. /package/dist/cjs/{data-structures → src/data-structures}/tree/index.d.ts +0 -0
  425. /package/dist/cjs/{data-structures → src/data-structures}/tree/index.js +0 -0
  426. /package/dist/cjs/{data-structures → src/data-structures}/tree/tree.d.ts +0 -0
  427. /package/dist/cjs/{data-structures → src/data-structures}/tree/tree.js +0 -0
  428. /package/dist/cjs/{data-structures → src/data-structures}/trie/index.d.ts +0 -0
  429. /package/dist/cjs/{data-structures → src/data-structures}/trie/index.js +0 -0
  430. /package/dist/cjs/{data-structures → src/data-structures}/trie/trie.d.ts +0 -0
  431. /package/dist/cjs/{data-structures → src/data-structures}/trie/trie.js +0 -0
  432. /package/dist/cjs/{index.d.ts → src/index.d.ts} +0 -0
  433. /package/dist/cjs/{index.js → src/index.js} +0 -0
  434. /package/dist/cjs/{interfaces → src/interfaces}/binary-tree.d.ts +0 -0
  435. /package/dist/cjs/{interfaces → src/interfaces}/binary-tree.js +0 -0
  436. /package/dist/cjs/{interfaces → src/interfaces}/doubly-linked-list.d.ts +0 -0
  437. /package/dist/cjs/{interfaces → src/interfaces}/doubly-linked-list.js +0 -0
  438. /package/dist/cjs/{interfaces → src/interfaces}/graph.d.ts +0 -0
  439. /package/dist/cjs/{interfaces → src/interfaces}/graph.js +0 -0
  440. /package/dist/cjs/{interfaces → src/interfaces}/heap.d.ts +0 -0
  441. /package/dist/cjs/{interfaces → src/interfaces}/heap.js +0 -0
  442. /package/dist/cjs/{interfaces → src/interfaces}/index.d.ts +0 -0
  443. /package/dist/cjs/{interfaces → src/interfaces}/index.js +0 -0
  444. /package/dist/cjs/{interfaces → src/interfaces}/navigator.d.ts +0 -0
  445. /package/dist/cjs/{interfaces → src/interfaces}/navigator.js +0 -0
  446. /package/dist/cjs/{interfaces → src/interfaces}/priority-queue.d.ts +0 -0
  447. /package/dist/cjs/{interfaces → src/interfaces}/priority-queue.js +0 -0
  448. /package/dist/cjs/{interfaces → src/interfaces}/segment-tree.d.ts +0 -0
  449. /package/dist/cjs/{interfaces → src/interfaces}/segment-tree.js +0 -0
  450. /package/dist/cjs/{interfaces → src/interfaces}/singly-linked-list.d.ts +0 -0
  451. /package/dist/cjs/{interfaces → src/interfaces}/singly-linked-list.js +0 -0
  452. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/avl-tree.d.ts +0 -0
  453. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/avl-tree.js +0 -0
  454. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/binary-indexed-tree.d.ts +0 -0
  455. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/binary-indexed-tree.js +0 -0
  456. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/binary-tree.d.ts +0 -0
  457. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/binary-tree.js +0 -0
  458. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/bst.d.ts +0 -0
  459. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/bst.js +0 -0
  460. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/index.d.ts +0 -0
  461. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/index.js +0 -0
  462. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/rb-tree.d.ts +0 -0
  463. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/rb-tree.js +0 -0
  464. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/segment-tree.d.ts +0 -0
  465. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/segment-tree.js +0 -0
  466. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/tree-multiset.d.ts +0 -0
  467. /package/dist/cjs/{types → src/types}/data-structures/binary-tree/tree-multiset.js +0 -0
  468. /package/dist/cjs/{types → src/types}/data-structures/graph/abstract-graph.d.ts +0 -0
  469. /package/dist/cjs/{types → src/types}/data-structures/graph/abstract-graph.js +0 -0
  470. /package/dist/cjs/{types → src/types}/data-structures/graph/directed-graph.d.ts +0 -0
  471. /package/dist/cjs/{types → src/types}/data-structures/graph/directed-graph.js +0 -0
  472. /package/dist/cjs/{types → src/types}/data-structures/graph/index.d.ts +0 -0
  473. /package/dist/cjs/{types → src/types}/data-structures/graph/index.js +0 -0
  474. /package/dist/cjs/{types → src/types}/data-structures/graph/map-graph.d.ts +0 -0
  475. /package/dist/cjs/{types → src/types}/data-structures/graph/map-graph.js +0 -0
  476. /package/dist/cjs/{types → src/types}/data-structures/graph/undirected-graph.d.ts +0 -0
  477. /package/dist/cjs/{types → src/types}/data-structures/graph/undirected-graph.js +0 -0
  478. /package/dist/cjs/{types → src/types}/data-structures/hash/coordinate-map.d.ts +0 -0
  479. /package/dist/cjs/{types → src/types}/data-structures/hash/coordinate-map.js +0 -0
  480. /package/dist/cjs/{types → src/types}/data-structures/hash/coordinate-set.d.ts +0 -0
  481. /package/dist/cjs/{types → src/types}/data-structures/hash/coordinate-set.js +0 -0
  482. /package/dist/cjs/{types → src/types}/data-structures/hash/hash-map.d.ts +0 -0
  483. /package/dist/cjs/{types → src/types}/data-structures/hash/hash-map.js +0 -0
  484. /package/dist/cjs/{types → src/types}/data-structures/hash/hash-table.d.ts +0 -0
  485. /package/dist/cjs/{types → src/types}/data-structures/hash/hash-table.js +0 -0
  486. /package/dist/cjs/{types → src/types}/data-structures/hash/index.d.ts +0 -0
  487. /package/dist/cjs/{types → src/types}/data-structures/hash/index.js +0 -0
  488. /package/dist/cjs/{types → src/types}/data-structures/hash/tree-map.d.ts +0 -0
  489. /package/dist/cjs/{types → src/types}/data-structures/hash/tree-map.js +0 -0
  490. /package/dist/cjs/{types → src/types}/data-structures/hash/tree-set.d.ts +0 -0
  491. /package/dist/cjs/{types → src/types}/data-structures/hash/tree-set.js +0 -0
  492. /package/dist/cjs/{types → src/types}/data-structures/heap/heap.d.ts +0 -0
  493. /package/dist/cjs/{types → src/types}/data-structures/heap/heap.js +0 -0
  494. /package/dist/cjs/{types → src/types}/data-structures/heap/index.d.ts +0 -0
  495. /package/dist/cjs/{types → src/types}/data-structures/heap/index.js +0 -0
  496. /package/dist/cjs/{types → src/types}/data-structures/heap/max-heap.d.ts +0 -0
  497. /package/dist/cjs/{types → src/types}/data-structures/heap/max-heap.js +0 -0
  498. /package/dist/cjs/{types → src/types}/data-structures/heap/min-heap.d.ts +0 -0
  499. /package/dist/cjs/{types → src/types}/data-structures/heap/min-heap.js +0 -0
  500. /package/dist/cjs/{types → src/types}/data-structures/index.d.ts +0 -0
  501. /package/dist/cjs/{types → src/types}/data-structures/index.js +0 -0
  502. /package/dist/cjs/{types → src/types}/data-structures/linked-list/doubly-linked-list.d.ts +0 -0
  503. /package/dist/cjs/{types → src/types}/data-structures/linked-list/doubly-linked-list.js +0 -0
  504. /package/dist/cjs/{types → src/types}/data-structures/linked-list/index.d.ts +0 -0
  505. /package/dist/cjs/{types → src/types}/data-structures/linked-list/index.js +0 -0
  506. /package/dist/cjs/{types → src/types}/data-structures/linked-list/singly-linked-list.d.ts +0 -0
  507. /package/dist/cjs/{types → src/types}/data-structures/linked-list/singly-linked-list.js +0 -0
  508. /package/dist/cjs/{types → src/types}/data-structures/linked-list/skip-linked-list.d.ts +0 -0
  509. /package/dist/cjs/{types → src/types}/data-structures/linked-list/skip-linked-list.js +0 -0
  510. /package/dist/cjs/{types → src/types}/data-structures/matrix/index.d.ts +0 -0
  511. /package/dist/cjs/{types → src/types}/data-structures/matrix/index.js +0 -0
  512. /package/dist/cjs/{types → src/types}/data-structures/matrix/matrix.d.ts +0 -0
  513. /package/dist/cjs/{types → src/types}/data-structures/matrix/matrix.js +0 -0
  514. /package/dist/cjs/{types → src/types}/data-structures/matrix/matrix2d.d.ts +0 -0
  515. /package/dist/cjs/{types → src/types}/data-structures/matrix/matrix2d.js +0 -0
  516. /package/dist/cjs/{types → src/types}/data-structures/matrix/navigator.d.ts +0 -0
  517. /package/dist/cjs/{types → src/types}/data-structures/matrix/navigator.js +0 -0
  518. /package/dist/cjs/{types → src/types}/data-structures/matrix/vector2d.d.ts +0 -0
  519. /package/dist/cjs/{types → src/types}/data-structures/matrix/vector2d.js +0 -0
  520. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/index.d.ts +0 -0
  521. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/index.js +0 -0
  522. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/max-priority-queue.d.ts +0 -0
  523. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/max-priority-queue.js +0 -0
  524. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/min-priority-queue.d.ts +0 -0
  525. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/min-priority-queue.js +0 -0
  526. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/priority-queue.d.ts +0 -0
  527. /package/dist/cjs/{types → src/types}/data-structures/priority-queue/priority-queue.js +0 -0
  528. /package/dist/cjs/{types → src/types}/data-structures/queue/deque.d.ts +0 -0
  529. /package/dist/cjs/{types → src/types}/data-structures/queue/deque.js +0 -0
  530. /package/dist/cjs/{types → src/types}/data-structures/queue/index.d.ts +0 -0
  531. /package/dist/cjs/{types → src/types}/data-structures/queue/index.js +0 -0
  532. /package/dist/cjs/{types → src/types}/data-structures/queue/queue.d.ts +0 -0
  533. /package/dist/cjs/{types → src/types}/data-structures/queue/queue.js +0 -0
  534. /package/dist/cjs/{types → src/types}/data-structures/stack/index.d.ts +0 -0
  535. /package/dist/cjs/{types → src/types}/data-structures/stack/index.js +0 -0
  536. /package/dist/cjs/{types → src/types}/data-structures/stack/stack.d.ts +0 -0
  537. /package/dist/cjs/{types → src/types}/data-structures/stack/stack.js +0 -0
  538. /package/dist/cjs/{types → src/types}/data-structures/tree/index.d.ts +0 -0
  539. /package/dist/cjs/{types → src/types}/data-structures/tree/index.js +0 -0
  540. /package/dist/cjs/{types → src/types}/data-structures/tree/tree.d.ts +0 -0
  541. /package/dist/cjs/{types → src/types}/data-structures/tree/tree.js +0 -0
  542. /package/dist/cjs/{types → src/types}/data-structures/trie/index.d.ts +0 -0
  543. /package/dist/cjs/{types → src/types}/data-structures/trie/index.js +0 -0
  544. /package/dist/cjs/{types → src/types}/data-structures/trie/trie.d.ts +0 -0
  545. /package/dist/cjs/{types → src/types}/data-structures/trie/trie.js +0 -0
  546. /package/dist/cjs/{types → src/types}/helpers.d.ts +0 -0
  547. /package/dist/cjs/{types → src/types}/helpers.js +0 -0
  548. /package/dist/cjs/{types → src/types}/index.d.ts +0 -0
  549. /package/dist/cjs/{types → src/types}/index.js +0 -0
  550. /package/dist/cjs/{types → src/types}/utils/index.d.ts +0 -0
  551. /package/dist/cjs/{types → src/types}/utils/index.js +0 -0
  552. /package/dist/cjs/{types → src/types}/utils/utils.d.ts +0 -0
  553. /package/dist/cjs/{types → src/types}/utils/utils.js +0 -0
  554. /package/dist/cjs/{types → src/types}/utils/validate-type.d.ts +0 -0
  555. /package/dist/cjs/{types → src/types}/utils/validate-type.js +0 -0
  556. /package/dist/cjs/{utils → src/utils}/index.d.ts +0 -0
  557. /package/dist/cjs/{utils → src/utils}/index.js +0 -0
  558. /package/dist/cjs/{utils → src/utils}/utils.d.ts +0 -0
  559. /package/dist/cjs/{utils → src/utils}/utils.js +0 -0
  560. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/binary-indexed-tree.d.ts +0 -0
  561. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/binary-indexed-tree.js +0 -0
  562. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/index.d.ts +0 -0
  563. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/index.js +0 -0
  564. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/rb-tree.d.ts +0 -0
  565. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/rb-tree.js +0 -0
  566. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/segment-tree.d.ts +0 -0
  567. /package/dist/mjs/{data-structures → src/data-structures}/binary-tree/segment-tree.js +0 -0
  568. /package/dist/mjs/{data-structures → src/data-structures}/graph/abstract-graph.d.ts +0 -0
  569. /package/dist/mjs/{data-structures → src/data-structures}/graph/abstract-graph.js +0 -0
  570. /package/dist/mjs/{data-structures → src/data-structures}/graph/directed-graph.d.ts +0 -0
  571. /package/dist/mjs/{data-structures → src/data-structures}/graph/directed-graph.js +0 -0
  572. /package/dist/mjs/{data-structures → src/data-structures}/graph/index.d.ts +0 -0
  573. /package/dist/mjs/{data-structures → src/data-structures}/graph/index.js +0 -0
  574. /package/dist/mjs/{data-structures → src/data-structures}/graph/map-graph.d.ts +0 -0
  575. /package/dist/mjs/{data-structures → src/data-structures}/graph/map-graph.js +0 -0
  576. /package/dist/mjs/{data-structures → src/data-structures}/graph/undirected-graph.d.ts +0 -0
  577. /package/dist/mjs/{data-structures → src/data-structures}/graph/undirected-graph.js +0 -0
  578. /package/dist/mjs/{data-structures → src/data-structures}/hash/coordinate-map.d.ts +0 -0
  579. /package/dist/mjs/{data-structures → src/data-structures}/hash/coordinate-map.js +0 -0
  580. /package/dist/mjs/{data-structures → src/data-structures}/hash/coordinate-set.d.ts +0 -0
  581. /package/dist/mjs/{data-structures → src/data-structures}/hash/coordinate-set.js +0 -0
  582. /package/dist/mjs/{data-structures → src/data-structures}/hash/hash-map.d.ts +0 -0
  583. /package/dist/mjs/{data-structures → src/data-structures}/hash/hash-map.js +0 -0
  584. /package/dist/mjs/{data-structures → src/data-structures}/hash/hash-table.d.ts +0 -0
  585. /package/dist/mjs/{data-structures → src/data-structures}/hash/hash-table.js +0 -0
  586. /package/dist/mjs/{data-structures → src/data-structures}/hash/index.d.ts +0 -0
  587. /package/dist/mjs/{data-structures → src/data-structures}/hash/index.js +0 -0
  588. /package/dist/mjs/{data-structures → src/data-structures}/hash/tree-map.d.ts +0 -0
  589. /package/dist/mjs/{data-structures → src/data-structures}/hash/tree-map.js +0 -0
  590. /package/dist/mjs/{data-structures → src/data-structures}/hash/tree-set.d.ts +0 -0
  591. /package/dist/mjs/{data-structures → src/data-structures}/hash/tree-set.js +0 -0
  592. /package/dist/mjs/{data-structures → src/data-structures}/heap/heap.d.ts +0 -0
  593. /package/dist/mjs/{data-structures → src/data-structures}/heap/heap.js +0 -0
  594. /package/dist/mjs/{data-structures → src/data-structures}/heap/index.d.ts +0 -0
  595. /package/dist/mjs/{data-structures → src/data-structures}/heap/index.js +0 -0
  596. /package/dist/mjs/{data-structures → src/data-structures}/heap/max-heap.d.ts +0 -0
  597. /package/dist/mjs/{data-structures → src/data-structures}/heap/max-heap.js +0 -0
  598. /package/dist/mjs/{data-structures → src/data-structures}/heap/min-heap.d.ts +0 -0
  599. /package/dist/mjs/{data-structures → src/data-structures}/heap/min-heap.js +0 -0
  600. /package/dist/mjs/{data-structures → src/data-structures}/index.d.ts +0 -0
  601. /package/dist/mjs/{data-structures → src/data-structures}/index.js +0 -0
  602. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/doubly-linked-list.d.ts +0 -0
  603. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/doubly-linked-list.js +0 -0
  604. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/index.d.ts +0 -0
  605. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/index.js +0 -0
  606. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/singly-linked-list.d.ts +0 -0
  607. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/singly-linked-list.js +0 -0
  608. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/skip-linked-list.d.ts +0 -0
  609. /package/dist/mjs/{data-structures → src/data-structures}/linked-list/skip-linked-list.js +0 -0
  610. /package/dist/mjs/{data-structures → src/data-structures}/matrix/index.d.ts +0 -0
  611. /package/dist/mjs/{data-structures → src/data-structures}/matrix/index.js +0 -0
  612. /package/dist/mjs/{data-structures → src/data-structures}/matrix/matrix.d.ts +0 -0
  613. /package/dist/mjs/{data-structures → src/data-structures}/matrix/matrix.js +0 -0
  614. /package/dist/mjs/{data-structures → src/data-structures}/matrix/matrix2d.d.ts +0 -0
  615. /package/dist/mjs/{data-structures → src/data-structures}/matrix/matrix2d.js +0 -0
  616. /package/dist/mjs/{data-structures → src/data-structures}/matrix/navigator.d.ts +0 -0
  617. /package/dist/mjs/{data-structures → src/data-structures}/matrix/navigator.js +0 -0
  618. /package/dist/mjs/{data-structures → src/data-structures}/matrix/vector2d.d.ts +0 -0
  619. /package/dist/mjs/{data-structures → src/data-structures}/matrix/vector2d.js +0 -0
  620. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/index.d.ts +0 -0
  621. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/index.js +0 -0
  622. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/max-priority-queue.d.ts +0 -0
  623. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/max-priority-queue.js +0 -0
  624. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/min-priority-queue.d.ts +0 -0
  625. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/min-priority-queue.js +0 -0
  626. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/priority-queue.d.ts +0 -0
  627. /package/dist/mjs/{data-structures → src/data-structures}/priority-queue/priority-queue.js +0 -0
  628. /package/dist/mjs/{data-structures → src/data-structures}/queue/deque.d.ts +0 -0
  629. /package/dist/mjs/{data-structures → src/data-structures}/queue/deque.js +0 -0
  630. /package/dist/mjs/{data-structures → src/data-structures}/queue/index.d.ts +0 -0
  631. /package/dist/mjs/{data-structures → src/data-structures}/queue/index.js +0 -0
  632. /package/dist/mjs/{data-structures → src/data-structures}/queue/queue.d.ts +0 -0
  633. /package/dist/mjs/{data-structures → src/data-structures}/queue/queue.js +0 -0
  634. /package/dist/mjs/{data-structures → src/data-structures}/stack/index.d.ts +0 -0
  635. /package/dist/mjs/{data-structures → src/data-structures}/stack/index.js +0 -0
  636. /package/dist/mjs/{data-structures → src/data-structures}/stack/stack.d.ts +0 -0
  637. /package/dist/mjs/{data-structures → src/data-structures}/stack/stack.js +0 -0
  638. /package/dist/mjs/{data-structures → src/data-structures}/tree/index.d.ts +0 -0
  639. /package/dist/mjs/{data-structures → src/data-structures}/tree/index.js +0 -0
  640. /package/dist/mjs/{data-structures → src/data-structures}/tree/tree.d.ts +0 -0
  641. /package/dist/mjs/{data-structures → src/data-structures}/tree/tree.js +0 -0
  642. /package/dist/mjs/{data-structures → src/data-structures}/trie/index.d.ts +0 -0
  643. /package/dist/mjs/{data-structures → src/data-structures}/trie/index.js +0 -0
  644. /package/dist/mjs/{data-structures → src/data-structures}/trie/trie.d.ts +0 -0
  645. /package/dist/mjs/{data-structures → src/data-structures}/trie/trie.js +0 -0
  646. /package/dist/mjs/{index.d.ts → src/index.d.ts} +0 -0
  647. /package/dist/mjs/{index.js → src/index.js} +0 -0
  648. /package/dist/mjs/{interfaces → src/interfaces}/binary-tree.d.ts +0 -0
  649. /package/dist/mjs/{interfaces → src/interfaces}/binary-tree.js +0 -0
  650. /package/dist/mjs/{interfaces → src/interfaces}/doubly-linked-list.d.ts +0 -0
  651. /package/dist/mjs/{interfaces → src/interfaces}/doubly-linked-list.js +0 -0
  652. /package/dist/mjs/{interfaces → src/interfaces}/graph.d.ts +0 -0
  653. /package/dist/mjs/{interfaces → src/interfaces}/graph.js +0 -0
  654. /package/dist/mjs/{interfaces → src/interfaces}/heap.d.ts +0 -0
  655. /package/dist/mjs/{interfaces → src/interfaces}/heap.js +0 -0
  656. /package/dist/mjs/{interfaces → src/interfaces}/index.d.ts +0 -0
  657. /package/dist/mjs/{interfaces → src/interfaces}/index.js +0 -0
  658. /package/dist/mjs/{interfaces → src/interfaces}/navigator.d.ts +0 -0
  659. /package/dist/mjs/{interfaces → src/interfaces}/navigator.js +0 -0
  660. /package/dist/mjs/{interfaces → src/interfaces}/priority-queue.d.ts +0 -0
  661. /package/dist/mjs/{interfaces → src/interfaces}/priority-queue.js +0 -0
  662. /package/dist/mjs/{interfaces → src/interfaces}/segment-tree.d.ts +0 -0
  663. /package/dist/mjs/{interfaces → src/interfaces}/segment-tree.js +0 -0
  664. /package/dist/mjs/{interfaces → src/interfaces}/singly-linked-list.d.ts +0 -0
  665. /package/dist/mjs/{interfaces → src/interfaces}/singly-linked-list.js +0 -0
  666. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/avl-tree.d.ts +0 -0
  667. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/avl-tree.js +0 -0
  668. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/binary-indexed-tree.d.ts +0 -0
  669. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/binary-indexed-tree.js +0 -0
  670. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/binary-tree.d.ts +0 -0
  671. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/binary-tree.js +0 -0
  672. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/bst.d.ts +0 -0
  673. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/bst.js +0 -0
  674. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/index.d.ts +0 -0
  675. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/index.js +0 -0
  676. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/rb-tree.d.ts +0 -0
  677. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/rb-tree.js +0 -0
  678. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/segment-tree.d.ts +0 -0
  679. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/segment-tree.js +0 -0
  680. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/tree-multiset.d.ts +0 -0
  681. /package/dist/mjs/{types → src/types}/data-structures/binary-tree/tree-multiset.js +0 -0
  682. /package/dist/mjs/{types → src/types}/data-structures/graph/abstract-graph.d.ts +0 -0
  683. /package/dist/mjs/{types → src/types}/data-structures/graph/abstract-graph.js +0 -0
  684. /package/dist/mjs/{types → src/types}/data-structures/graph/directed-graph.d.ts +0 -0
  685. /package/dist/mjs/{types → src/types}/data-structures/graph/directed-graph.js +0 -0
  686. /package/dist/mjs/{types → src/types}/data-structures/graph/index.d.ts +0 -0
  687. /package/dist/mjs/{types → src/types}/data-structures/graph/index.js +0 -0
  688. /package/dist/mjs/{types → src/types}/data-structures/graph/map-graph.d.ts +0 -0
  689. /package/dist/mjs/{types → src/types}/data-structures/graph/map-graph.js +0 -0
  690. /package/dist/mjs/{types → src/types}/data-structures/graph/undirected-graph.d.ts +0 -0
  691. /package/dist/mjs/{types → src/types}/data-structures/graph/undirected-graph.js +0 -0
  692. /package/dist/mjs/{types → src/types}/data-structures/hash/coordinate-map.d.ts +0 -0
  693. /package/dist/mjs/{types → src/types}/data-structures/hash/coordinate-map.js +0 -0
  694. /package/dist/mjs/{types → src/types}/data-structures/hash/coordinate-set.d.ts +0 -0
  695. /package/dist/mjs/{types → src/types}/data-structures/hash/coordinate-set.js +0 -0
  696. /package/dist/mjs/{types → src/types}/data-structures/hash/hash-map.d.ts +0 -0
  697. /package/dist/mjs/{types → src/types}/data-structures/hash/hash-map.js +0 -0
  698. /package/dist/mjs/{types → src/types}/data-structures/hash/hash-table.d.ts +0 -0
  699. /package/dist/mjs/{types → src/types}/data-structures/hash/hash-table.js +0 -0
  700. /package/dist/mjs/{types → src/types}/data-structures/hash/index.d.ts +0 -0
  701. /package/dist/mjs/{types → src/types}/data-structures/hash/index.js +0 -0
  702. /package/dist/mjs/{types → src/types}/data-structures/hash/tree-map.d.ts +0 -0
  703. /package/dist/mjs/{types → src/types}/data-structures/hash/tree-map.js +0 -0
  704. /package/dist/mjs/{types → src/types}/data-structures/hash/tree-set.d.ts +0 -0
  705. /package/dist/mjs/{types → src/types}/data-structures/hash/tree-set.js +0 -0
  706. /package/dist/mjs/{types → src/types}/data-structures/heap/heap.d.ts +0 -0
  707. /package/dist/mjs/{types → src/types}/data-structures/heap/heap.js +0 -0
  708. /package/dist/mjs/{types → src/types}/data-structures/heap/index.d.ts +0 -0
  709. /package/dist/mjs/{types → src/types}/data-structures/heap/index.js +0 -0
  710. /package/dist/mjs/{types → src/types}/data-structures/heap/max-heap.d.ts +0 -0
  711. /package/dist/mjs/{types → src/types}/data-structures/heap/max-heap.js +0 -0
  712. /package/dist/mjs/{types → src/types}/data-structures/heap/min-heap.d.ts +0 -0
  713. /package/dist/mjs/{types → src/types}/data-structures/heap/min-heap.js +0 -0
  714. /package/dist/mjs/{types → src/types}/data-structures/index.d.ts +0 -0
  715. /package/dist/mjs/{types → src/types}/data-structures/index.js +0 -0
  716. /package/dist/mjs/{types → src/types}/data-structures/linked-list/doubly-linked-list.d.ts +0 -0
  717. /package/dist/mjs/{types → src/types}/data-structures/linked-list/doubly-linked-list.js +0 -0
  718. /package/dist/mjs/{types → src/types}/data-structures/linked-list/index.d.ts +0 -0
  719. /package/dist/mjs/{types → src/types}/data-structures/linked-list/index.js +0 -0
  720. /package/dist/mjs/{types → src/types}/data-structures/linked-list/singly-linked-list.d.ts +0 -0
  721. /package/dist/mjs/{types → src/types}/data-structures/linked-list/singly-linked-list.js +0 -0
  722. /package/dist/mjs/{types → src/types}/data-structures/linked-list/skip-linked-list.d.ts +0 -0
  723. /package/dist/mjs/{types → src/types}/data-structures/linked-list/skip-linked-list.js +0 -0
  724. /package/dist/mjs/{types → src/types}/data-structures/matrix/index.d.ts +0 -0
  725. /package/dist/mjs/{types → src/types}/data-structures/matrix/index.js +0 -0
  726. /package/dist/mjs/{types → src/types}/data-structures/matrix/matrix.d.ts +0 -0
  727. /package/dist/mjs/{types → src/types}/data-structures/matrix/matrix.js +0 -0
  728. /package/dist/mjs/{types → src/types}/data-structures/matrix/matrix2d.d.ts +0 -0
  729. /package/dist/mjs/{types → src/types}/data-structures/matrix/matrix2d.js +0 -0
  730. /package/dist/mjs/{types → src/types}/data-structures/matrix/navigator.d.ts +0 -0
  731. /package/dist/mjs/{types → src/types}/data-structures/matrix/navigator.js +0 -0
  732. /package/dist/mjs/{types → src/types}/data-structures/matrix/vector2d.d.ts +0 -0
  733. /package/dist/mjs/{types → src/types}/data-structures/matrix/vector2d.js +0 -0
  734. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/index.d.ts +0 -0
  735. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/index.js +0 -0
  736. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/max-priority-queue.d.ts +0 -0
  737. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/max-priority-queue.js +0 -0
  738. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/min-priority-queue.d.ts +0 -0
  739. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/min-priority-queue.js +0 -0
  740. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/priority-queue.d.ts +0 -0
  741. /package/dist/mjs/{types → src/types}/data-structures/priority-queue/priority-queue.js +0 -0
  742. /package/dist/mjs/{types → src/types}/data-structures/queue/deque.d.ts +0 -0
  743. /package/dist/mjs/{types → src/types}/data-structures/queue/deque.js +0 -0
  744. /package/dist/mjs/{types → src/types}/data-structures/queue/index.d.ts +0 -0
  745. /package/dist/mjs/{types → src/types}/data-structures/queue/index.js +0 -0
  746. /package/dist/mjs/{types → src/types}/data-structures/queue/queue.d.ts +0 -0
  747. /package/dist/mjs/{types → src/types}/data-structures/queue/queue.js +0 -0
  748. /package/dist/mjs/{types → src/types}/data-structures/stack/index.d.ts +0 -0
  749. /package/dist/mjs/{types → src/types}/data-structures/stack/index.js +0 -0
  750. /package/dist/mjs/{types → src/types}/data-structures/stack/stack.d.ts +0 -0
  751. /package/dist/mjs/{types → src/types}/data-structures/stack/stack.js +0 -0
  752. /package/dist/mjs/{types → src/types}/data-structures/tree/index.d.ts +0 -0
  753. /package/dist/mjs/{types → src/types}/data-structures/tree/index.js +0 -0
  754. /package/dist/mjs/{types → src/types}/data-structures/tree/tree.d.ts +0 -0
  755. /package/dist/mjs/{types → src/types}/data-structures/tree/tree.js +0 -0
  756. /package/dist/mjs/{types → src/types}/data-structures/trie/index.d.ts +0 -0
  757. /package/dist/mjs/{types → src/types}/data-structures/trie/index.js +0 -0
  758. /package/dist/mjs/{types → src/types}/data-structures/trie/trie.d.ts +0 -0
  759. /package/dist/mjs/{types → src/types}/data-structures/trie/trie.js +0 -0
  760. /package/dist/mjs/{types → src/types}/helpers.d.ts +0 -0
  761. /package/dist/mjs/{types → src/types}/helpers.js +0 -0
  762. /package/dist/mjs/{types → src/types}/index.d.ts +0 -0
  763. /package/dist/mjs/{types → src/types}/index.js +0 -0
  764. /package/dist/mjs/{types → src/types}/utils/index.d.ts +0 -0
  765. /package/dist/mjs/{types → src/types}/utils/index.js +0 -0
  766. /package/dist/mjs/{types → src/types}/utils/utils.d.ts +0 -0
  767. /package/dist/mjs/{types → src/types}/utils/utils.js +0 -0
  768. /package/dist/mjs/{types → src/types}/utils/validate-type.d.ts +0 -0
  769. /package/dist/mjs/{types → src/types}/utils/validate-type.js +0 -0
  770. /package/dist/mjs/{utils → src/utils}/index.d.ts +0 -0
  771. /package/dist/mjs/{utils → src/utils}/index.js +0 -0
  772. /package/dist/mjs/{utils → src/utils}/utils.d.ts +0 -0
  773. /package/dist/mjs/{utils → src/utils}/utils.js +0 -0
@@ -1,345 +0,0 @@
1
- import {Matrix2D, Vector2D} from '../../../../src';
2
- import {isDebugTest} from '../../../config';
3
-
4
- const isDebug = isDebugTest;
5
- describe('Matrix2D', () => {
6
- it('should initialize with default identity matrix', () => {
7
- const matrix = new Matrix2D();
8
- const expectedMatrix = Matrix2D.identity;
9
-
10
- expect(matrix.m).toEqual(expectedMatrix);
11
- });
12
-
13
- it('should initialize with provided 2D array', () => {
14
- const inputMatrix = [
15
- [2, 0, 0],
16
- [0, 3, 0],
17
- [0, 0, 1]
18
- ];
19
- const matrix = new Matrix2D(inputMatrix);
20
-
21
- expect(matrix.m).toEqual(inputMatrix);
22
- });
23
-
24
- it('should initialize with provided Vector2D', () => {
25
- expect(true).toBeTruthy();
26
- });
27
-
28
- it('should add two matrices correctly', () => {
29
- const matrix1 = new Matrix2D([
30
- [1, 2, 3],
31
- [4, 5, 6],
32
- [7, 8, 9]
33
- ]);
34
- const matrix2 = new Matrix2D([
35
- [9, 8, 7],
36
- [6, 5, 4],
37
- [3, 2, 1]
38
- ]);
39
- const expectedMatrix = [
40
- [10, 10, 10],
41
- [10, 10, 10],
42
- [10, 10, 10]
43
- ];
44
-
45
- const result = Matrix2D.add(matrix1, matrix2);
46
-
47
- expect(result.m).toEqual(expectedMatrix);
48
- });
49
-
50
- it('should subtract two matrices correctly', () => {
51
- const matrix1 = new Matrix2D([
52
- [9, 8, 7],
53
- [6, 5, 4],
54
- [3, 2, 1]
55
- ]);
56
- const matrix2 = new Matrix2D([
57
- [1, 2, 3],
58
- [4, 5, 6],
59
- [7, 8, 9]
60
- ]);
61
- const expectedMatrix = [
62
- [8, 6, 4],
63
- [2, 0, -2],
64
- [-4, -6, -8]
65
- ];
66
-
67
- const result = Matrix2D.subtract(matrix1, matrix2);
68
-
69
- expect(result.m).toEqual(expectedMatrix);
70
- });
71
-
72
- it('should multiply two matrices correctly', () => {
73
- const matrix1 = new Matrix2D([
74
- [1, 2, 3],
75
- [4, 5, 6],
76
- [7, 8, 9]
77
- ]);
78
- const matrix2 = new Matrix2D([
79
- [9, 8, 7],
80
- [6, 5, 4],
81
- [3, 2, 1]
82
- ]);
83
- const expectedMatrix = [
84
- [30, 24, 18],
85
- [84, 69, 54],
86
- [138, 114, 90]
87
- ];
88
-
89
- const result = Matrix2D.multiply(matrix1, matrix2);
90
-
91
- expect(result.m).toEqual(expectedMatrix);
92
- });
93
-
94
- it('should multiply a matrix by a Vector2D correctly', () => {
95
- expect(true).toBeTruthy();
96
- });
97
-
98
- it('should scale a matrix by a value correctly', () => {
99
- expect(true).toBeTruthy();
100
- });
101
-
102
- it('should rotate a matrix by radians correctly', () => {
103
- expect(true).toBeTruthy();
104
- });
105
-
106
- it('should translate a matrix by a Vector2D correctly', () => {
107
- const translationVector = new Vector2D(2, 3);
108
- const expectedMatrix = [
109
- [1, 0, 2],
110
- [0, 1, 3],
111
- [0, 0, 1]
112
- ];
113
-
114
- const result = Matrix2D.translate(translationVector);
115
-
116
- expect(result.m).toEqual(expectedMatrix);
117
- });
118
-
119
- it('should create a view matrix correctly', () => {
120
- expect(true).toBeTruthy();
121
- });
122
-
123
- it('should multiply a matrix by a value correctly', () => {
124
- const matrix = new Matrix2D([
125
- [1, 2, 3],
126
- [4, 5, 6],
127
- [7, 8, 9]
128
- ]);
129
- const value = 2;
130
- const expectedMatrix = [
131
- [2, 4, 6],
132
- [8, 10, 12],
133
- [14, 16, 18]
134
- ];
135
-
136
- const result = Matrix2D.multiplyByValue(matrix, value);
137
-
138
- expect(result.m).toEqual(expectedMatrix);
139
- });
140
- });
141
-
142
- describe('Vector2D', () => {
143
- it('should create a vector with default values', () => {
144
- const vector = new Vector2D();
145
- expect(vector.x).toBe(0);
146
- expect(vector.y).toBe(0);
147
- expect(vector.w).toBe(1);
148
- });
149
-
150
- it('should correctly calculate vector length', () => {
151
- const vector = new Vector2D(3, 4);
152
- expect(vector.length).toBe(5);
153
- });
154
-
155
- it('should correctly add two vectors', () => {
156
- const vector1 = new Vector2D(2, 3);
157
- const vector2 = new Vector2D(1, 2);
158
- const result = Vector2D.add(vector1, vector2);
159
- expect(result.x).toBe(3);
160
- expect(result.y).toBe(5);
161
- });
162
-
163
- // Add more test cases for Vector2D methods
164
- });
165
-
166
- describe('Matrix2D', () => {
167
- it('should create an identity matrix by default', () => {
168
- const matrix = new Matrix2D();
169
- expect(matrix.m).toEqual(Matrix2D.identity);
170
- });
171
-
172
- it('should correctly add two matrices', () => {
173
- const matrix1 = new Matrix2D([
174
- [1, 2, 3],
175
- [4, 5, 6],
176
- [7, 8, 9]
177
- ]);
178
- const matrix2 = new Matrix2D([
179
- [9, 8, 7],
180
- [6, 5, 4],
181
- [3, 2, 1]
182
- ]);
183
- const result = Matrix2D.add(matrix1, matrix2);
184
- expect(result.m).toEqual([
185
- [10, 10, 10],
186
- [10, 10, 10],
187
- [10, 10, 10]
188
- ]);
189
- });
190
-
191
- // Add more test cases for Matrix2D methods
192
- });
193
-
194
- describe('Matrix2D', () => {
195
- it('should create a matrix with default identity values', () => {
196
- const matrix = new Matrix2D();
197
- expect(matrix.m).toEqual(Matrix2D.identity);
198
- });
199
-
200
- it('should create a matrix from a Vector2D', () => {
201
- const vector = new Vector2D(2, 3);
202
- const matrix = new Matrix2D(vector);
203
- expect(matrix.m).toEqual([
204
- [2, 0, 0],
205
- [3, 1, 0],
206
- [1, 0, 1]
207
- ]);
208
- });
209
-
210
- it('should correctly add two matrices', () => {
211
- const matrix1 = new Matrix2D([
212
- [1, 2, 3],
213
- [4, 5, 6],
214
- [7, 8, 9]
215
- ]);
216
- const matrix2 = new Matrix2D([
217
- [9, 8, 7],
218
- [6, 5, 4],
219
- [3, 2, 1]
220
- ]);
221
- const result = Matrix2D.add(matrix1, matrix2);
222
- expect(result.m).toEqual([
223
- [10, 10, 10],
224
- [10, 10, 10],
225
- [10, 10, 10]
226
- ]);
227
- });
228
-
229
- it('should correctly subtract two matrices', () => {
230
- const matrix1 = new Matrix2D([
231
- [5, 4, 3],
232
- [2, 1, 0],
233
- [0, 1, 2]
234
- ]);
235
- const matrix2 = new Matrix2D([
236
- [4, 3, 2],
237
- [1, 0, 1],
238
- [2, 1, 0]
239
- ]);
240
- const result = Matrix2D.subtract(matrix1, matrix2);
241
- expect(result.m).toEqual([
242
- [1, 1, 1],
243
- [1, 1, -1],
244
- [-2, 0, 2]
245
- ]);
246
- });
247
-
248
- it('should correctly multiply two matrices', () => {
249
- const matrix1 = new Matrix2D([
250
- [1, 2, 3],
251
- [4, 5, 6],
252
- [7, 8, 9]
253
- ]);
254
- const matrix2 = new Matrix2D([
255
- [9, 8, 7],
256
- [6, 5, 4],
257
- [3, 2, 1]
258
- ]);
259
- const result = Matrix2D.multiply(matrix1, matrix2);
260
- expect(result.m).toEqual([
261
- [30, 24, 18],
262
- [84, 69, 54],
263
- [138, 114, 90]
264
- ]);
265
- });
266
-
267
- it('should correctly multiply a matrix by a value', () => {
268
- const matrix = new Matrix2D([
269
- [2, 3, 4],
270
- [5, 6, 7],
271
- [8, 9, 10]
272
- ]);
273
- const value = 2;
274
- const result = Matrix2D.multiplyByValue(matrix, value);
275
- expect(result.m).toEqual([
276
- [4, 6, 8],
277
- [10, 12, 14],
278
- [16, 18, 20]
279
- ]);
280
- });
281
-
282
- it('should correctly multiply a matrix by a vector', () => {
283
- const matrix = new Matrix2D([
284
- [2, 3, 4],
285
- [5, 6, 7],
286
- [8, 9, 10]
287
- ]);
288
- const vector = new Vector2D(2, 3);
289
- const result = Matrix2D.multiplyByVector(matrix, vector);
290
- isDebug && console.log(JSON.stringify(result));
291
- expect(result).toEqual({x: 17, y: 35, w: 1});
292
- });
293
-
294
- it('should correctly create a view matrix', () => {
295
- const width = 800;
296
- const height = 600;
297
- const viewMatrix = Matrix2D.view(width, height);
298
- expect(viewMatrix.m).toEqual([
299
- [1, 0, 400],
300
- [0, -1, 300],
301
- [0, 0, 1]
302
- ]);
303
- });
304
-
305
- it('should correctly scale a matrix', () => {
306
- const factor = 3;
307
- const scaledMatrix = Matrix2D.scale(factor);
308
- expect(scaledMatrix.m).toEqual([
309
- [3, 0, 0],
310
- [0, 3, 0],
311
- [0, 0, 3]
312
- ]);
313
- });
314
-
315
- it('should correctly rotate a matrix', () => {
316
- const radians = Math.PI / 4; // 45 degrees
317
- const rotationMatrix = Matrix2D.rotate(radians);
318
- isDebug && console.log(JSON.stringify(rotationMatrix.m));
319
- expect(rotationMatrix.m).toEqual([
320
- [0.7071067811865476, -0.7071067811865475, 0],
321
- [0.7071067811865475, 0.7071067811865476, 0],
322
- [0, 0, 1]
323
- ]);
324
- });
325
-
326
- it('should correctly translate a matrix', () => {
327
- const translationVector = new Vector2D(2, 3);
328
- const translationMatrix = Matrix2D.translate(translationVector);
329
- expect(translationMatrix.m).toEqual([
330
- [1, 0, 2],
331
- [0, 1, 3],
332
- [0, 0, 1]
333
- ]);
334
- });
335
-
336
- it('should correctly convert a matrix to a vector', () => {
337
- const matrix = new Matrix2D([
338
- [2, 3, 4],
339
- [5, 6, 7],
340
- [8, 9, 10]
341
- ]);
342
- const vector = matrix.toVector();
343
- expect(vector).toEqual(new Vector2D(2, 5));
344
- });
345
- });
@@ -1,244 +0,0 @@
1
- import {Character, Navigator, NavigatorParams, Turning} from '../../../../src';
2
- import {isDebugTest} from '../../../config';
3
-
4
- const isDebug = isDebugTest;
5
- const exampleMatrix: number[][] = [
6
- [0, 0, 0, 0],
7
- [0, 1, 1, 0],
8
- [0, 0, 0, 0]
9
- ];
10
-
11
- // Create a sample redirect object
12
- const exampleTurning: Turning = {
13
- up: 'right',
14
- right: 'down',
15
- down: 'left',
16
- left: 'up'
17
- };
18
-
19
- // Create a sample move callback function
20
- const exampleOnMove = () => {
21
- expect(true).toBeTruthy();
22
- // isDebug && console.log(`Moved to position (${cur[0]}, ${cur[1]})`);
23
- };
24
-
25
- // Create an initial parameter object for the example
26
- const exampleInit: NavigatorParams<number>['init'] = {
27
- cur: [0, 0],
28
- charDir: 'right',
29
- VISITED: -1
30
- };
31
-
32
- // Create a Navigator Params object
33
- const exampleNavigatorParams: NavigatorParams<number> = {
34
- matrix: exampleMatrix,
35
- turning: exampleTurning,
36
- onMove: exampleOnMove,
37
- init: exampleInit
38
- };
39
-
40
- describe('Character class', () => {
41
- it('should create a character with the correct direction', () => {
42
- const character = new Character('up', exampleTurning);
43
- expect(character.direction).toBe('up');
44
- });
45
-
46
- it('should turn the character in the correct direction', () => {
47
- const character = new Character('up', exampleTurning);
48
- const turnedCharacter = character.turn();
49
- expect(turnedCharacter.direction).toBe('right');
50
- });
51
- });
52
-
53
- describe('Navigator class', () => {
54
- let navigator: Navigator<number>;
55
-
56
- beforeEach(() => {
57
- navigator = new Navigator(exampleNavigatorParams);
58
- });
59
-
60
- it('should initialize with the correct matrix and current position', () => {
61
- expect(navigator['_matrix']).toEqual(exampleMatrix);
62
- expect(navigator['_cur']).toEqual(exampleInit.cur);
63
- });
64
-
65
- it('should move the character correctly', () => {
66
- navigator.move('right');
67
- expect(navigator['_cur']).toEqual([0, 1]);
68
- expect(navigator['_matrix'][0][1]).toBe(exampleInit.VISITED);
69
- });
70
-
71
- it('should turn the character correctly', () => {
72
- expect(navigator['_character'].direction).toBe('right');
73
- });
74
-
75
- it('should check for valid moves correctly', () => {
76
- expect(navigator.check('up')).toBe(false); // Blocked by wall
77
- expect(navigator.check('right')).toBe(true); // Open path
78
- expect(navigator.check('down')).toBe(true); // Blocked by wall
79
- expect(navigator.check('left')).toBe(false); // Open path
80
- });
81
- });
82
-
83
- describe('Navigator', () => {
84
- it('should correctly navigate the grid', () => {
85
- // Define a sample grid and initial parameters
86
- const matrix: number[][] = [
87
- [0, 0, 1],
88
- [0, 1, 0],
89
- [0, 0, 0]
90
- ];
91
-
92
- const turning: Turning = {
93
- up: 'right',
94
- right: 'down',
95
- down: 'left',
96
- left: 'up'
97
- };
98
-
99
- const init: NavigatorParams<number>['init'] = {
100
- cur: [0, 0], // Initial position
101
- charDir: 'right', // Initial character direction
102
- VISITED: 2 // Value to mark visited cells
103
- };
104
-
105
- // Initialize the navigator
106
- const navigator = new Navigator({
107
- matrix,
108
- turning,
109
- init,
110
- onMove: cur => cur
111
- });
112
-
113
- // Define a function to track visited cells
114
- const visitedCells: number[][] = [];
115
- const onMove = (cur: number[]) => {
116
- visitedCells.push([...cur]);
117
- };
118
-
119
- // Attach the onMove function
120
- navigator.onMove = onMove;
121
-
122
- // Start the navigation
123
- navigator.start();
124
-
125
- // The character should have navigated the grid correctly
126
- expect(visitedCells).toEqual([
127
- [0, 1],
128
- [0, 2],
129
- [1, 2],
130
- [2, 2],
131
- [2, 1],
132
- [2, 0],
133
- [1, 0],
134
- [1, 1]
135
- ]);
136
- });
137
-
138
- it('should not move if there are no valid moves', () => {
139
- // Define a sample grid with no valid moves
140
- const matrix: number[][] = [
141
- [1, 1],
142
- [1, 1]
143
- ];
144
-
145
- const turning: Turning = {
146
- up: 'right',
147
- right: 'down',
148
- down: 'left',
149
- left: 'up'
150
- };
151
-
152
- const init: NavigatorParams<number>['init'] = {
153
- cur: [0, 0], // Initial position
154
- charDir: 'right', // Initial character direction
155
- VISITED: 2 // Value to mark visited cells
156
- };
157
-
158
- // Initialize the navigator
159
- const navigator = new Navigator({
160
- matrix,
161
- turning,
162
- init,
163
- onMove: cur => cur
164
- });
165
-
166
- // Define a function to track visited cells
167
- const visitedCells: number[][] = [];
168
- const onMove = (cur: number[]) => {
169
- visitedCells.push([...cur]);
170
- };
171
-
172
- // Attach the onMove function
173
- navigator.onMove = onMove;
174
-
175
- // Start the navigation
176
- navigator.start();
177
-
178
- // The character should not move
179
- isDebug && console.log(visitedCells);
180
- expect(visitedCells).toEqual([
181
- [0, 1],
182
- [1, 1],
183
- [1, 0]
184
- ]);
185
- });
186
-
187
- it('should handle edge cases and turns correctly', () => {
188
- // Define a sample grid with turns and edge cases
189
- const matrix: number[][] = [
190
- [1, 0, 0, 0],
191
- [1, 0, 1, 0],
192
- [0, 0, 1, 1]
193
- ];
194
-
195
- const turning: Turning = {
196
- up: 'right',
197
- right: 'down',
198
- down: 'left',
199
- left: 'up'
200
- };
201
-
202
- const init: NavigatorParams<number>['init'] = {
203
- cur: [0, 0], // Initial position
204
- charDir: 'right', // Initial character direction
205
- VISITED: 2 // Value to mark visited cells
206
- };
207
-
208
- // Initialize the navigator
209
- const navigator = new Navigator({
210
- matrix,
211
- turning,
212
- init,
213
- onMove: cur => cur
214
- });
215
-
216
- // Define a function to track visited cells
217
- const visitedCells: number[][] = [];
218
- const onMove = (cur: number[]) => {
219
- visitedCells.push([...cur]);
220
- };
221
-
222
- // Attach the onMove function
223
- navigator.onMove = onMove;
224
-
225
- // Start the navigation
226
- navigator.start();
227
-
228
- // The character should have navigated the grid, handled turns, and edge cases
229
- isDebug && console.log(visitedCells);
230
- expect(visitedCells).toEqual([
231
- [0, 1],
232
- [0, 2],
233
- [0, 3],
234
- [1, 3],
235
- [2, 3],
236
- [2, 2],
237
- [2, 1],
238
- [2, 0],
239
- [1, 0],
240
- [1, 1],
241
- [1, 2]
242
- ]);
243
- });
244
- });