tree-multimap-typed 1.42.5

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 (366) hide show
  1. package/.dependency-cruiser.js +449 -0
  2. package/.eslintrc.js +65 -0
  3. package/.prettierignore +6 -0
  4. package/.prettierrc.js +16 -0
  5. package/LICENSE +21 -0
  6. package/README.md +527 -0
  7. package/coverage/clover.xml +14 -0
  8. package/coverage/coverage-final.json +96 -0
  9. package/coverage/coverage-summary.json +60 -0
  10. package/coverage/lcov-report/base.css +403 -0
  11. package/coverage/lcov-report/block-navigation.js +87 -0
  12. package/coverage/lcov-report/favicon.png +0 -0
  13. package/coverage/lcov-report/index.html +120 -0
  14. package/coverage/lcov-report/index.ts.html +110 -0
  15. package/coverage/lcov-report/prettify.css +1 -0
  16. package/coverage/lcov-report/prettify.js +2 -0
  17. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  18. package/coverage/lcov-report/sorter.js +206 -0
  19. package/coverage/lcov.info +14 -0
  20. package/dist/data-structures/binary-tree/avl-tree.d.ts +106 -0
  21. package/dist/data-structures/binary-tree/avl-tree.js +349 -0
  22. package/dist/data-structures/binary-tree/binary-indexed-tree.d.ts +149 -0
  23. package/dist/data-structures/binary-tree/binary-indexed-tree.js +269 -0
  24. package/dist/data-structures/binary-tree/binary-tree.d.ts +322 -0
  25. package/dist/data-structures/binary-tree/binary-tree.js +1305 -0
  26. package/dist/data-structures/binary-tree/bst.d.ts +175 -0
  27. package/dist/data-structures/binary-tree/bst.js +546 -0
  28. package/dist/data-structures/binary-tree/index.d.ts +7 -0
  29. package/dist/data-structures/binary-tree/index.js +23 -0
  30. package/dist/data-structures/binary-tree/rb-tree.d.ts +93 -0
  31. package/dist/data-structures/binary-tree/rb-tree.js +434 -0
  32. package/dist/data-structures/binary-tree/segment-tree.d.ts +67 -0
  33. package/dist/data-structures/binary-tree/segment-tree.js +180 -0
  34. package/dist/data-structures/binary-tree/tree-multimap.d.ts +126 -0
  35. package/dist/data-structures/binary-tree/tree-multimap.js +358 -0
  36. package/dist/data-structures/graph/abstract-graph.d.ts +347 -0
  37. package/dist/data-structures/graph/abstract-graph.js +936 -0
  38. package/dist/data-structures/graph/directed-graph.d.ts +194 -0
  39. package/dist/data-structures/graph/directed-graph.js +404 -0
  40. package/dist/data-structures/graph/index.d.ts +4 -0
  41. package/dist/data-structures/graph/index.js +20 -0
  42. package/dist/data-structures/graph/map-graph.d.ts +73 -0
  43. package/dist/data-structures/graph/map-graph.js +93 -0
  44. package/dist/data-structures/graph/undirected-graph.d.ts +120 -0
  45. package/dist/data-structures/graph/undirected-graph.js +239 -0
  46. package/dist/data-structures/hash/coordinate-map.d.ts +44 -0
  47. package/dist/data-structures/hash/coordinate-map.js +62 -0
  48. package/dist/data-structures/hash/coordinate-set.d.ts +36 -0
  49. package/dist/data-structures/hash/coordinate-set.js +52 -0
  50. package/dist/data-structures/hash/hash-map.d.ts +50 -0
  51. package/dist/data-structures/hash/hash-map.js +153 -0
  52. package/dist/data-structures/hash/hash-table.d.ts +103 -0
  53. package/dist/data-structures/hash/hash-table.js +236 -0
  54. package/dist/data-structures/hash/index.d.ts +6 -0
  55. package/dist/data-structures/hash/index.js +22 -0
  56. package/dist/data-structures/hash/tree-map.d.ts +2 -0
  57. package/dist/data-structures/hash/tree-map.js +6 -0
  58. package/dist/data-structures/hash/tree-set.d.ts +2 -0
  59. package/dist/data-structures/hash/tree-set.js +6 -0
  60. package/dist/data-structures/heap/heap.d.ts +235 -0
  61. package/dist/data-structures/heap/heap.js +515 -0
  62. package/dist/data-structures/heap/index.d.ts +3 -0
  63. package/dist/data-structures/heap/index.js +19 -0
  64. package/dist/data-structures/heap/max-heap.d.ts +15 -0
  65. package/dist/data-structures/heap/max-heap.js +26 -0
  66. package/dist/data-structures/heap/min-heap.d.ts +15 -0
  67. package/dist/data-structures/heap/min-heap.js +26 -0
  68. package/dist/data-structures/index.d.ts +11 -0
  69. package/dist/data-structures/index.js +27 -0
  70. package/dist/data-structures/linked-list/doubly-linked-list.d.ts +253 -0
  71. package/dist/data-structures/linked-list/doubly-linked-list.js +569 -0
  72. package/dist/data-structures/linked-list/index.d.ts +3 -0
  73. package/dist/data-structures/linked-list/index.js +19 -0
  74. package/dist/data-structures/linked-list/singly-linked-list.d.ts +232 -0
  75. package/dist/data-structures/linked-list/singly-linked-list.js +533 -0
  76. package/dist/data-structures/linked-list/skip-linked-list.d.ts +80 -0
  77. package/dist/data-structures/linked-list/skip-linked-list.js +187 -0
  78. package/dist/data-structures/matrix/index.d.ts +4 -0
  79. package/dist/data-structures/matrix/index.js +20 -0
  80. package/dist/data-structures/matrix/matrix.d.ts +21 -0
  81. package/dist/data-structures/matrix/matrix.js +28 -0
  82. package/dist/data-structures/matrix/matrix2d.d.ts +107 -0
  83. package/dist/data-structures/matrix/matrix2d.js +199 -0
  84. package/dist/data-structures/matrix/navigator.d.ts +52 -0
  85. package/dist/data-structures/matrix/navigator.js +106 -0
  86. package/dist/data-structures/matrix/vector2d.d.ts +200 -0
  87. package/dist/data-structures/matrix/vector2d.js +290 -0
  88. package/dist/data-structures/priority-queue/index.d.ts +3 -0
  89. package/dist/data-structures/priority-queue/index.js +19 -0
  90. package/dist/data-structures/priority-queue/max-priority-queue.d.ts +15 -0
  91. package/dist/data-structures/priority-queue/max-priority-queue.js +26 -0
  92. package/dist/data-structures/priority-queue/min-priority-queue.d.ts +15 -0
  93. package/dist/data-structures/priority-queue/min-priority-queue.js +26 -0
  94. package/dist/data-structures/priority-queue/priority-queue.d.ts +15 -0
  95. package/dist/data-structures/priority-queue/priority-queue.js +17 -0
  96. package/dist/data-structures/queue/deque.d.ts +161 -0
  97. package/dist/data-structures/queue/deque.js +264 -0
  98. package/dist/data-structures/queue/index.d.ts +2 -0
  99. package/dist/data-structures/queue/index.js +18 -0
  100. package/dist/data-structures/queue/queue.d.ts +122 -0
  101. package/dist/data-structures/queue/queue.js +187 -0
  102. package/dist/data-structures/stack/index.d.ts +1 -0
  103. package/dist/data-structures/stack/index.js +17 -0
  104. package/dist/data-structures/stack/stack.d.ts +64 -0
  105. package/dist/data-structures/stack/stack.js +94 -0
  106. package/dist/data-structures/tree/index.d.ts +1 -0
  107. package/dist/data-structures/tree/index.js +17 -0
  108. package/dist/data-structures/tree/tree.d.ts +8 -0
  109. package/dist/data-structures/tree/tree.js +40 -0
  110. package/dist/data-structures/trie/index.d.ts +1 -0
  111. package/dist/data-structures/trie/index.js +17 -0
  112. package/dist/data-structures/trie/trie.d.ts +79 -0
  113. package/dist/data-structures/trie/trie.js +251 -0
  114. package/dist/index.d.ts +10 -0
  115. package/dist/index.js +27 -0
  116. package/dist/interfaces/binary-tree.d.ts +7 -0
  117. package/dist/interfaces/binary-tree.js +2 -0
  118. package/dist/interfaces/doubly-linked-list.d.ts +1 -0
  119. package/dist/interfaces/doubly-linked-list.js +2 -0
  120. package/dist/interfaces/graph.d.ts +5 -0
  121. package/dist/interfaces/graph.js +2 -0
  122. package/dist/interfaces/heap.d.ts +1 -0
  123. package/dist/interfaces/heap.js +2 -0
  124. package/dist/interfaces/index.d.ts +8 -0
  125. package/dist/interfaces/index.js +24 -0
  126. package/dist/interfaces/navigator.d.ts +1 -0
  127. package/dist/interfaces/navigator.js +2 -0
  128. package/dist/interfaces/priority-queue.d.ts +1 -0
  129. package/dist/interfaces/priority-queue.js +2 -0
  130. package/dist/interfaces/segment-tree.d.ts +1 -0
  131. package/dist/interfaces/segment-tree.js +2 -0
  132. package/dist/interfaces/singly-linked-list.d.ts +1 -0
  133. package/dist/interfaces/singly-linked-list.js +2 -0
  134. package/dist/types/data-structures/binary-tree/avl-tree.d.ts +4 -0
  135. package/dist/types/data-structures/binary-tree/avl-tree.js +2 -0
  136. package/dist/types/data-structures/binary-tree/binary-indexed-tree.d.ts +1 -0
  137. package/dist/types/data-structures/binary-tree/binary-indexed-tree.js +2 -0
  138. package/dist/types/data-structures/binary-tree/binary-tree.d.ts +29 -0
  139. package/dist/types/data-structures/binary-tree/binary-tree.js +24 -0
  140. package/dist/types/data-structures/binary-tree/bst.d.ts +7 -0
  141. package/dist/types/data-structures/binary-tree/bst.js +2 -0
  142. package/dist/types/data-structures/binary-tree/index.d.ts +6 -0
  143. package/dist/types/data-structures/binary-tree/index.js +22 -0
  144. package/dist/types/data-structures/binary-tree/rb-tree.d.ts +8 -0
  145. package/dist/types/data-structures/binary-tree/rb-tree.js +8 -0
  146. package/dist/types/data-structures/binary-tree/segment-tree.d.ts +1 -0
  147. package/dist/types/data-structures/binary-tree/segment-tree.js +2 -0
  148. package/dist/types/data-structures/binary-tree/tree-multimap.d.ts +4 -0
  149. package/dist/types/data-structures/binary-tree/tree-multimap.js +2 -0
  150. package/dist/types/data-structures/graph/abstract-graph.d.ts +10 -0
  151. package/dist/types/data-structures/graph/abstract-graph.js +2 -0
  152. package/dist/types/data-structures/graph/directed-graph.d.ts +6 -0
  153. package/dist/types/data-structures/graph/directed-graph.js +9 -0
  154. package/dist/types/data-structures/graph/index.d.ts +3 -0
  155. package/dist/types/data-structures/graph/index.js +19 -0
  156. package/dist/types/data-structures/graph/map-graph.d.ts +1 -0
  157. package/dist/types/data-structures/graph/map-graph.js +2 -0
  158. package/dist/types/data-structures/graph/undirected-graph.d.ts +1 -0
  159. package/dist/types/data-structures/graph/undirected-graph.js +2 -0
  160. package/dist/types/data-structures/hash/coordinate-map.d.ts +1 -0
  161. package/dist/types/data-structures/hash/coordinate-map.js +2 -0
  162. package/dist/types/data-structures/hash/coordinate-set.d.ts +1 -0
  163. package/dist/types/data-structures/hash/coordinate-set.js +2 -0
  164. package/dist/types/data-structures/hash/hash-map.d.ts +1 -0
  165. package/dist/types/data-structures/hash/hash-map.js +2 -0
  166. package/dist/types/data-structures/hash/hash-table.d.ts +1 -0
  167. package/dist/types/data-structures/hash/hash-table.js +2 -0
  168. package/dist/types/data-structures/hash/index.d.ts +1 -0
  169. package/dist/types/data-structures/hash/index.js +2 -0
  170. package/dist/types/data-structures/hash/tree-map.d.ts +1 -0
  171. package/dist/types/data-structures/hash/tree-map.js +2 -0
  172. package/dist/types/data-structures/hash/tree-set.d.ts +1 -0
  173. package/dist/types/data-structures/hash/tree-set.js +2 -0
  174. package/dist/types/data-structures/heap/heap.d.ts +1 -0
  175. package/dist/types/data-structures/heap/heap.js +2 -0
  176. package/dist/types/data-structures/heap/index.d.ts +1 -0
  177. package/dist/types/data-structures/heap/index.js +17 -0
  178. package/dist/types/data-structures/heap/max-heap.d.ts +1 -0
  179. package/dist/types/data-structures/heap/max-heap.js +2 -0
  180. package/dist/types/data-structures/heap/min-heap.d.ts +1 -0
  181. package/dist/types/data-structures/heap/min-heap.js +2 -0
  182. package/dist/types/data-structures/index.d.ts +11 -0
  183. package/dist/types/data-structures/index.js +27 -0
  184. package/dist/types/data-structures/linked-list/doubly-linked-list.d.ts +1 -0
  185. package/dist/types/data-structures/linked-list/doubly-linked-list.js +2 -0
  186. package/dist/types/data-structures/linked-list/index.d.ts +2 -0
  187. package/dist/types/data-structures/linked-list/index.js +18 -0
  188. package/dist/types/data-structures/linked-list/singly-linked-list.d.ts +1 -0
  189. package/dist/types/data-structures/linked-list/singly-linked-list.js +2 -0
  190. package/dist/types/data-structures/linked-list/skip-linked-list.d.ts +1 -0
  191. package/dist/types/data-structures/linked-list/skip-linked-list.js +2 -0
  192. package/dist/types/data-structures/matrix/index.d.ts +1 -0
  193. package/dist/types/data-structures/matrix/index.js +17 -0
  194. package/dist/types/data-structures/matrix/matrix.d.ts +1 -0
  195. package/dist/types/data-structures/matrix/matrix.js +2 -0
  196. package/dist/types/data-structures/matrix/matrix2d.d.ts +1 -0
  197. package/dist/types/data-structures/matrix/matrix2d.js +2 -0
  198. package/dist/types/data-structures/matrix/navigator.d.ts +14 -0
  199. package/dist/types/data-structures/matrix/navigator.js +2 -0
  200. package/dist/types/data-structures/matrix/vector2d.d.ts +1 -0
  201. package/dist/types/data-structures/matrix/vector2d.js +2 -0
  202. package/dist/types/data-structures/priority-queue/index.d.ts +3 -0
  203. package/dist/types/data-structures/priority-queue/index.js +19 -0
  204. package/dist/types/data-structures/priority-queue/max-priority-queue.d.ts +1 -0
  205. package/dist/types/data-structures/priority-queue/max-priority-queue.js +2 -0
  206. package/dist/types/data-structures/priority-queue/min-priority-queue.d.ts +1 -0
  207. package/dist/types/data-structures/priority-queue/min-priority-queue.js +2 -0
  208. package/dist/types/data-structures/priority-queue/priority-queue.d.ts +1 -0
  209. package/dist/types/data-structures/priority-queue/priority-queue.js +2 -0
  210. package/dist/types/data-structures/queue/deque.d.ts +1 -0
  211. package/dist/types/data-structures/queue/deque.js +2 -0
  212. package/dist/types/data-structures/queue/index.d.ts +2 -0
  213. package/dist/types/data-structures/queue/index.js +18 -0
  214. package/dist/types/data-structures/queue/queue.d.ts +1 -0
  215. package/dist/types/data-structures/queue/queue.js +2 -0
  216. package/dist/types/data-structures/stack/index.d.ts +1 -0
  217. package/dist/types/data-structures/stack/index.js +17 -0
  218. package/dist/types/data-structures/stack/stack.d.ts +1 -0
  219. package/dist/types/data-structures/stack/stack.js +2 -0
  220. package/dist/types/data-structures/tree/index.d.ts +1 -0
  221. package/dist/types/data-structures/tree/index.js +17 -0
  222. package/dist/types/data-structures/tree/tree.d.ts +1 -0
  223. package/dist/types/data-structures/tree/tree.js +2 -0
  224. package/dist/types/data-structures/trie/index.d.ts +1 -0
  225. package/dist/types/data-structures/trie/index.js +17 -0
  226. package/dist/types/data-structures/trie/trie.d.ts +1 -0
  227. package/dist/types/data-structures/trie/trie.js +2 -0
  228. package/dist/types/helpers.d.ts +8 -0
  229. package/dist/types/helpers.js +9 -0
  230. package/dist/types/index.d.ts +3 -0
  231. package/dist/types/index.js +19 -0
  232. package/dist/types/utils/index.d.ts +2 -0
  233. package/dist/types/utils/index.js +18 -0
  234. package/dist/types/utils/utils.d.ts +7 -0
  235. package/dist/types/utils/utils.js +2 -0
  236. package/dist/types/utils/validate-type.d.ts +19 -0
  237. package/dist/types/utils/validate-type.js +2 -0
  238. package/dist/utils/index.d.ts +1 -0
  239. package/dist/utils/index.js +17 -0
  240. package/dist/utils/utils.d.ts +20 -0
  241. package/dist/utils/utils.js +73 -0
  242. package/docs/.nojekyll +1 -0
  243. package/docs/assets/highlight.css +50 -0
  244. package/docs/assets/main.js +59 -0
  245. package/docs/assets/navigation.js +1 -0
  246. package/docs/assets/search.js +1 -0
  247. package/docs/assets/style.css +1383 -0
  248. package/docs/classes/TreeMultiset.html +2376 -0
  249. package/docs/classes/TreeMultisetNode.html +313 -0
  250. package/docs/index.html +523 -0
  251. package/docs/modules.html +45 -0
  252. package/jest.config.js +8 -0
  253. package/package.json +184 -0
  254. package/src/data-structures/binary-tree/avl-tree.ts +352 -0
  255. package/src/data-structures/binary-tree/binary-indexed-tree.ts +306 -0
  256. package/src/data-structures/binary-tree/binary-tree.ts +1558 -0
  257. package/src/data-structures/binary-tree/bst.ts +564 -0
  258. package/src/data-structures/binary-tree/index.ts +7 -0
  259. package/src/data-structures/binary-tree/rb-tree.ts +486 -0
  260. package/src/data-structures/binary-tree/segment-tree.ts +190 -0
  261. package/src/data-structures/binary-tree/tree-multimap.ts +381 -0
  262. package/src/data-structures/graph/abstract-graph.ts +1056 -0
  263. package/src/data-structures/graph/directed-graph.ts +450 -0
  264. package/src/data-structures/graph/index.ts +4 -0
  265. package/src/data-structures/graph/map-graph.ts +106 -0
  266. package/src/data-structures/graph/undirected-graph.ts +260 -0
  267. package/src/data-structures/hash/coordinate-map.ts +63 -0
  268. package/src/data-structures/hash/coordinate-set.ts +52 -0
  269. package/src/data-structures/hash/hash-map.ts +185 -0
  270. package/src/data-structures/hash/hash-table.ts +268 -0
  271. package/src/data-structures/hash/index.ts +6 -0
  272. package/src/data-structures/hash/tree-map.ts +1 -0
  273. package/src/data-structures/hash/tree-set.ts +1 -0
  274. package/src/data-structures/heap/heap.ts +589 -0
  275. package/src/data-structures/heap/index.ts +3 -0
  276. package/src/data-structures/heap/max-heap.ts +26 -0
  277. package/src/data-structures/heap/min-heap.ts +26 -0
  278. package/src/data-structures/index.ts +11 -0
  279. package/src/data-structures/linked-list/doubly-linked-list.ts +605 -0
  280. package/src/data-structures/linked-list/index.ts +3 -0
  281. package/src/data-structures/linked-list/singly-linked-list.ts +576 -0
  282. package/src/data-structures/linked-list/skip-linked-list.ts +221 -0
  283. package/src/data-structures/matrix/index.ts +4 -0
  284. package/src/data-structures/matrix/matrix.ts +27 -0
  285. package/src/data-structures/matrix/matrix2d.ts +211 -0
  286. package/src/data-structures/matrix/navigator.ts +121 -0
  287. package/src/data-structures/matrix/vector2d.ts +314 -0
  288. package/src/data-structures/priority-queue/index.ts +3 -0
  289. package/src/data-structures/priority-queue/max-priority-queue.ts +25 -0
  290. package/src/data-structures/priority-queue/min-priority-queue.ts +25 -0
  291. package/src/data-structures/priority-queue/priority-queue.ts +16 -0
  292. package/src/data-structures/queue/deque.ts +281 -0
  293. package/src/data-structures/queue/index.ts +2 -0
  294. package/src/data-structures/queue/queue.ts +209 -0
  295. package/src/data-structures/stack/index.ts +1 -0
  296. package/src/data-structures/stack/stack.ts +102 -0
  297. package/src/data-structures/tree/index.ts +1 -0
  298. package/src/data-structures/tree/tree.ts +41 -0
  299. package/src/data-structures/trie/index.ts +1 -0
  300. package/src/data-structures/trie/trie.ts +262 -0
  301. package/src/index.ts +11 -0
  302. package/src/interfaces/binary-tree.ts +10 -0
  303. package/src/interfaces/doubly-linked-list.ts +1 -0
  304. package/src/interfaces/graph.ts +7 -0
  305. package/src/interfaces/heap.ts +1 -0
  306. package/src/interfaces/index.ts +8 -0
  307. package/src/interfaces/navigator.ts +1 -0
  308. package/src/interfaces/priority-queue.ts +1 -0
  309. package/src/interfaces/segment-tree.ts +1 -0
  310. package/src/interfaces/singly-linked-list.ts +1 -0
  311. package/src/types/data-structures/binary-tree/avl-tree.ts +5 -0
  312. package/src/types/data-structures/binary-tree/binary-indexed-tree.ts +1 -0
  313. package/src/types/data-structures/binary-tree/binary-tree.ts +31 -0
  314. package/src/types/data-structures/binary-tree/bst.ts +11 -0
  315. package/src/types/data-structures/binary-tree/index.ts +6 -0
  316. package/src/types/data-structures/binary-tree/rb-tree.ts +8 -0
  317. package/src/types/data-structures/binary-tree/segment-tree.ts +1 -0
  318. package/src/types/data-structures/binary-tree/tree-multimap.ts +6 -0
  319. package/src/types/data-structures/graph/abstract-graph.ts +11 -0
  320. package/src/types/data-structures/graph/directed-graph.ts +8 -0
  321. package/src/types/data-structures/graph/index.ts +3 -0
  322. package/src/types/data-structures/graph/map-graph.ts +1 -0
  323. package/src/types/data-structures/graph/undirected-graph.ts +1 -0
  324. package/src/types/data-structures/hash/coordinate-map.ts +1 -0
  325. package/src/types/data-structures/hash/coordinate-set.ts +1 -0
  326. package/src/types/data-structures/hash/hash-map.ts +1 -0
  327. package/src/types/data-structures/hash/hash-table.ts +1 -0
  328. package/src/types/data-structures/hash/index.ts +1 -0
  329. package/src/types/data-structures/hash/tree-map.ts +1 -0
  330. package/src/types/data-structures/hash/tree-set.ts +1 -0
  331. package/src/types/data-structures/heap/heap.ts +1 -0
  332. package/src/types/data-structures/heap/index.ts +1 -0
  333. package/src/types/data-structures/heap/max-heap.ts +1 -0
  334. package/src/types/data-structures/heap/min-heap.ts +1 -0
  335. package/src/types/data-structures/index.ts +11 -0
  336. package/src/types/data-structures/linked-list/doubly-linked-list.ts +1 -0
  337. package/src/types/data-structures/linked-list/index.ts +2 -0
  338. package/src/types/data-structures/linked-list/singly-linked-list.ts +1 -0
  339. package/src/types/data-structures/linked-list/skip-linked-list.ts +1 -0
  340. package/src/types/data-structures/matrix/index.ts +1 -0
  341. package/src/types/data-structures/matrix/matrix.ts +1 -0
  342. package/src/types/data-structures/matrix/matrix2d.ts +1 -0
  343. package/src/types/data-structures/matrix/navigator.ts +14 -0
  344. package/src/types/data-structures/matrix/vector2d.ts +1 -0
  345. package/src/types/data-structures/priority-queue/index.ts +3 -0
  346. package/src/types/data-structures/priority-queue/max-priority-queue.ts +1 -0
  347. package/src/types/data-structures/priority-queue/min-priority-queue.ts +1 -0
  348. package/src/types/data-structures/priority-queue/priority-queue.ts +1 -0
  349. package/src/types/data-structures/queue/deque.ts +1 -0
  350. package/src/types/data-structures/queue/index.ts +2 -0
  351. package/src/types/data-structures/queue/queue.ts +1 -0
  352. package/src/types/data-structures/stack/index.ts +1 -0
  353. package/src/types/data-structures/stack/stack.ts +1 -0
  354. package/src/types/data-structures/tree/index.ts +1 -0
  355. package/src/types/data-structures/tree/tree.ts +1 -0
  356. package/src/types/data-structures/trie/index.ts +1 -0
  357. package/src/types/data-structures/trie/trie.ts +1 -0
  358. package/src/types/helpers.ts +11 -0
  359. package/src/types/index.ts +3 -0
  360. package/src/types/utils/index.ts +2 -0
  361. package/src/types/utils/utils.ts +6 -0
  362. package/src/types/utils/validate-type.ts +35 -0
  363. package/src/utils/index.ts +1 -0
  364. package/src/utils/utils.ts +86 -0
  365. package/test/index.test.ts +461 -0
  366. package/tsconfig.json +38 -0
@@ -0,0 +1,461 @@
1
+ import {TreeMultimap, TreeMultimapNode} from '../src';
2
+
3
+ describe('TreeMultimap operations test', () => {
4
+ it('should perform various operations on a Binary Search Tree with numeric values', () => {
5
+ const treeMultiset = new TreeMultimap();
6
+
7
+ expect(treeMultiset instanceof TreeMultimap);
8
+ treeMultiset.add(11, 11);
9
+ treeMultiset.add(3, 3);
10
+ const idAndValues = [11, 3, 15, 1, 8, 13, 16, 2, 6, 9, 12, 14, 4, 7, 10, 5];
11
+ treeMultiset.addMany(idAndValues, idAndValues);
12
+ expect(treeMultiset.root instanceof TreeMultimapNode);
13
+
14
+ if (treeMultiset.root) expect(treeMultiset.root.id == 11);
15
+
16
+ expect(treeMultiset.size).toBe(16);
17
+ expect(treeMultiset.count).toBe(18);
18
+ expect(treeMultiset.BFS('id'));
19
+
20
+ expect(treeMultiset.has(6));
21
+
22
+ expect(treeMultiset.getHeight(6)).toBe(3);
23
+ expect(treeMultiset.getDepth(6)).toBe(1);
24
+ const nodeId10 = treeMultiset.get(10);
25
+ expect(nodeId10?.id).toBe(10);
26
+
27
+ const nodeVal9 = treeMultiset.get(9, 'val');
28
+ expect(nodeVal9?.id).toBe(9);
29
+
30
+ const nodesByCount1 = treeMultiset.getNodesByCount(1);
31
+ expect(nodesByCount1.length).toBe(14);
32
+
33
+ const nodesByCount2 = treeMultiset.getNodesByCount(2);
34
+ expect(nodesByCount2.length).toBe(2);
35
+ const leftMost = treeMultiset.getLeftMost();
36
+ expect(leftMost?.id).toBe(1);
37
+
38
+ const node15 = treeMultiset.get(15);
39
+ const minNodeBySpecificNode = node15 && treeMultiset.getLeftMost(node15);
40
+ expect(minNodeBySpecificNode?.id).toBe(12);
41
+
42
+ const subTreeSum = node15 && treeMultiset.subTreeSum(15);
43
+ expect(subTreeSum).toBe(70);
44
+ const lesserSum = treeMultiset.lesserSum(10);
45
+ expect(lesserSum).toBe(45);
46
+
47
+ expect(node15 instanceof TreeMultimapNode);
48
+ if (node15 instanceof TreeMultimapNode) {
49
+ const subTreeAdd = treeMultiset.subTreeAddCount(15, 1);
50
+ expect(subTreeAdd);
51
+ }
52
+ const node11 = treeMultiset.get(11);
53
+ expect(node11 instanceof TreeMultimapNode);
54
+ if (node11 instanceof TreeMultimapNode) {
55
+ const allGreaterNodesAdded = treeMultiset.allGreaterNodesAddCount(11, 2);
56
+ expect(allGreaterNodesAdded);
57
+ }
58
+
59
+ const dfsInorderNodes = treeMultiset.DFS('in', 'node');
60
+ expect(dfsInorderNodes[0].id).toBe(1);
61
+ expect(dfsInorderNodes[dfsInorderNodes.length - 1].id).toBe(16);
62
+ expect(treeMultiset.isPerfectlyBalanced()).toBe(false);
63
+
64
+ treeMultiset.perfectlyBalance();
65
+
66
+ expect(treeMultiset.isPerfectlyBalanced()).toBe(true);
67
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
68
+
69
+ const bfsNodesAfterBalanced = treeMultiset.BFS('node');
70
+ expect(bfsNodesAfterBalanced[0].id).toBe(8);
71
+ expect(bfsNodesAfterBalanced[bfsNodesAfterBalanced.length - 1].id).toBe(16);
72
+
73
+ const removed11 = treeMultiset.remove(11, true);
74
+ expect(removed11 instanceof Array);
75
+ expect(removed11[0]);
76
+ expect(removed11[0].deleted);
77
+
78
+ if (removed11[0].deleted) expect(removed11[0].deleted.id).toBe(11);
79
+
80
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
81
+
82
+ expect(treeMultiset.getHeight(15)).toBe(1);
83
+
84
+ const removed1 = treeMultiset.remove(1, true);
85
+ expect(removed1 instanceof Array);
86
+ expect(removed1[0]);
87
+ expect(removed1[0].deleted);
88
+ if (removed1[0].deleted) expect(removed1[0].deleted.id).toBe(1);
89
+
90
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
91
+
92
+ expect(treeMultiset.getHeight()).toBe(4);
93
+
94
+ const removed4 = treeMultiset.remove(4, true);
95
+ expect(removed4 instanceof Array);
96
+ expect(removed4[0]);
97
+ expect(removed4[0].deleted);
98
+ if (removed4[0].deleted) expect(removed4[0].deleted.id).toBe(4);
99
+
100
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
101
+ expect(treeMultiset.getHeight()).toBe(4);
102
+
103
+ const removed10 = treeMultiset.remove(10, true);
104
+ expect(removed10 instanceof Array);
105
+ expect(removed10[0]);
106
+ expect(removed10[0].deleted);
107
+ if (removed10[0].deleted) expect(removed10[0].deleted.id).toBe(10);
108
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
109
+
110
+ expect(treeMultiset.getHeight()).toBe(3);
111
+
112
+ const removed15 = treeMultiset.remove(15, true);
113
+ expect(removed15 instanceof Array);
114
+ expect(removed15[0]);
115
+ expect(removed15[0].deleted);
116
+ if (removed15[0].deleted) expect(removed15[0].deleted.id).toBe(15);
117
+
118
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
119
+ expect(treeMultiset.getHeight()).toBe(3);
120
+
121
+ const removed5 = treeMultiset.remove(5, true);
122
+ expect(removed5 instanceof Array);
123
+ expect(removed5[0]);
124
+ expect(removed5[0].deleted);
125
+ if (removed5[0].deleted) expect(removed5[0].deleted.id).toBe(5);
126
+
127
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
128
+ expect(treeMultiset.getHeight()).toBe(3);
129
+
130
+ const removed13 = treeMultiset.remove(13, true);
131
+ expect(removed13 instanceof Array);
132
+ expect(removed13[0]);
133
+ expect(removed13[0].deleted);
134
+ if (removed13[0].deleted) expect(removed13[0].deleted.id).toBe(13);
135
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
136
+ expect(treeMultiset.getHeight()).toBe(3);
137
+
138
+ const removed3 = treeMultiset.remove(3, true);
139
+ expect(removed3 instanceof Array);
140
+ expect(removed3[0]);
141
+ expect(removed3[0].deleted);
142
+ if (removed3[0].deleted) expect(removed3[0].deleted.id).toBe(3);
143
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
144
+ expect(treeMultiset.getHeight()).toBe(3);
145
+
146
+ const removed8 = treeMultiset.remove(8, true);
147
+ expect(removed8 instanceof Array);
148
+ expect(removed8[0]);
149
+ expect(removed8[0].deleted);
150
+ if (removed8[0].deleted) expect(removed8[0].deleted.id).toBe(8);
151
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
152
+ expect(treeMultiset.getHeight()).toBe(3);
153
+
154
+ const removed6 = treeMultiset.remove(6, true);
155
+ expect(removed6 instanceof Array);
156
+ expect(removed6[0]);
157
+ expect(removed6[0].deleted);
158
+ if (removed6[0].deleted) expect(removed6[0].deleted.id).toBe(6);
159
+ expect(treeMultiset.remove(6, true).length).toBe(0);
160
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
161
+
162
+ expect(treeMultiset.getHeight()).toBe(2);
163
+
164
+ const removed7 = treeMultiset.remove(7, true);
165
+ expect(removed7 instanceof Array);
166
+ expect(removed7[0]);
167
+ expect(removed7[0].deleted);
168
+ if (removed7[0].deleted) expect(removed7[0].deleted.id).toBe(7);
169
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
170
+ expect(treeMultiset.getHeight()).toBe(2);
171
+
172
+ const removed9 = treeMultiset.remove(9, true);
173
+ expect(removed9 instanceof Array);
174
+ expect(removed9[0]);
175
+ expect(removed9[0].deleted);
176
+ if (removed9[0].deleted) expect(removed9[0].deleted.id).toBe(9);
177
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
178
+ expect(treeMultiset.getHeight()).toBe(2);
179
+
180
+ const removed14 = treeMultiset.remove(14, true);
181
+ expect(removed14 instanceof Array);
182
+ expect(removed14[0]);
183
+ expect(removed14[0].deleted);
184
+ if (removed14[0].deleted) expect(removed14[0].deleted.id).toBe(14);
185
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
186
+ expect(treeMultiset.getHeight()).toBe(1);
187
+
188
+ expect(treeMultiset.isAVLBalanced()).toBe(true);
189
+
190
+ const bfsIDs = treeMultiset.BFS();
191
+
192
+ expect(bfsIDs[0]).toBe(12);
193
+ expect(bfsIDs[1]).toBe(2);
194
+ expect(bfsIDs[2]).toBe(16);
195
+
196
+ const bfsNodes = treeMultiset.BFS('node');
197
+
198
+ expect(bfsNodes[0].id).toBe(12);
199
+ expect(bfsNodes[1].id).toBe(2);
200
+ expect(bfsNodes[2].id).toBe(16);
201
+
202
+ expect(treeMultiset.count).toBe(9);
203
+ });
204
+
205
+ it('should perform various operations on a Binary Search Tree with object values', () => {
206
+ const objTreeMultimap = new TreeMultimap<TreeMultimapNode<{ id: number; keyA: number }>>();
207
+ expect(objTreeMultimap).toBeInstanceOf(TreeMultimap);
208
+ objTreeMultimap.add(11, {id: 11, keyA: 11});
209
+ objTreeMultimap.add(3, {id: 3, keyA: 3});
210
+ const values = [
211
+ {id: 15, keyA: 15},
212
+ {id: 1, keyA: 1},
213
+ {id: 8, keyA: 8},
214
+ {id: 13, keyA: 13},
215
+ {id: 16, keyA: 16},
216
+ {id: 2, keyA: 2},
217
+ {id: 6, keyA: 6},
218
+ {id: 9, keyA: 9},
219
+ {id: 12, keyA: 12},
220
+ {id: 14, keyA: 14},
221
+ {id: 4, keyA: 4},
222
+ {id: 7, keyA: 7},
223
+ {id: 10, keyA: 10},
224
+ {id: 5, keyA: 5}
225
+ ];
226
+
227
+ objTreeMultimap.addMany(
228
+ values.map(item => item.id),
229
+ values
230
+ );
231
+
232
+ expect(objTreeMultimap.root).toBeInstanceOf(TreeMultimapNode);
233
+
234
+ if (objTreeMultimap.root) expect(objTreeMultimap.root.id).toBe(11);
235
+
236
+ expect(objTreeMultimap.count).toBe(16);
237
+
238
+ expect(objTreeMultimap.has(6)).toBe(true);
239
+
240
+ // const node6 = objTreeMultimap.get(6);
241
+ // expect(node6 && objTreeMultimap.getHeight(node6)).toBe(2);
242
+ // expect(node6 && objTreeMultimap.getDepth(node6)).toBe(3);
243
+ //
244
+ // const nodeId10 = objTreeMultimap.get(10, 'id');
245
+ // expect(nodeId10?.id).toBe(10);
246
+ //
247
+ // const nodeVal9 = objTreeMultimap.get(9, 'id');
248
+ // expect(nodeVal9?.id).toBe(9);
249
+ //
250
+ // const nodesByCount1 = objTreeMultimap.getNodesByCount(1);
251
+ // expect(nodesByCount1.length).toBe(16);
252
+ //
253
+ // const leftMost = objTreeMultimap.getLeftMost();
254
+ // expect(leftMost?.id).toBe(1);
255
+ //
256
+ // const node15 = objTreeMultimap.get(15);
257
+ // expect(node15?.val).toEqual({id: 15, keyA: 15});
258
+ // const minNodeBySpecificNode = node15 && objTreeMultimap.getLeftMost(node15);
259
+ // expect(minNodeBySpecificNode?.id).toBe(12);
260
+ //
261
+ // const subTreeSum = node15 && objTreeMultimap.subTreeSum(node15);
262
+ // expect(subTreeSum).toBe(70);
263
+ //
264
+ // const lesserSum = objTreeMultimap.lesserSum(10);
265
+ // expect(lesserSum).toBe(45);
266
+ //
267
+ // expect(node15).toBeInstanceOf(TreeMultimapNode);
268
+ // if (node15 instanceof TreeMultimapNode) {
269
+ // const subTreeAdd = objTreeMultimap.subTreeAddCount(node15, 1);
270
+ // expect(subTreeAdd).toBeDefined();
271
+ // }
272
+ //
273
+ // const node11 = objTreeMultimap.get(11);
274
+ // expect(node11).toBeInstanceOf(TreeMultimapNode);
275
+ // if (node11 instanceof TreeMultimapNode) {
276
+ // const allGreaterNodesAdded = objTreeMultimap.allGreaterNodesAddCount(node11, 2);
277
+ // expect(allGreaterNodesAdded).toBeDefined();
278
+ // }
279
+ //
280
+ // const dfsInorderNodes = objTreeMultimap.DFS('in', 'node');
281
+ // expect(dfsInorderNodes[0].id).toBe(1);
282
+ // expect(dfsInorderNodes[dfsInorderNodes.length - 1].id).toBe(16);
283
+ //
284
+ // objTreeMultimap.perfectlyBalance();
285
+ // expect(objTreeMultimap.isPerfectlyBalanced()).toBe(true);
286
+ //
287
+ // const bfsNodesAfterBalanced = objTreeMultimap.BFS('node');
288
+ // expect(bfsNodesAfterBalanced[0].id).toBe(8);
289
+ // expect(bfsNodesAfterBalanced[bfsNodesAfterBalanced.length - 1].id).toBe(16);
290
+ //
291
+ // const removed11 = objTreeMultimap.remove(11, true);
292
+ // expect(removed11).toBeInstanceOf(Array);
293
+ // expect(removed11[0]).toBeDefined();
294
+ // expect(removed11[0].deleted).toBeDefined();
295
+ //
296
+ // if (removed11[0].deleted) expect(removed11[0].deleted.id).toBe(11);
297
+ //
298
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(true);
299
+ //
300
+ // expect(node15 && objTreeMultimap.getHeight(node15)).toBe(2);
301
+ //
302
+ // const removed1 = objTreeMultimap.remove(1, true);
303
+ // expect(removed1).toBeInstanceOf(Array);
304
+ // expect(removed1[0]).toBeDefined();
305
+ // expect(removed1[0].deleted).toBeDefined();
306
+ // if (removed1[0].deleted) expect(removed1[0].deleted.id).toBe(1);
307
+ //
308
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(true);
309
+ //
310
+ // expect(objTreeMultimap.getHeight()).toBe(4);
311
+ //
312
+ // const removed4 = objTreeMultimap.remove(4, true);
313
+ // expect(removed4).toBeInstanceOf(Array);
314
+ // expect(removed4[0]).toBeDefined();
315
+ // expect(removed4[0].deleted).toBeDefined();
316
+ // if (removed4[0].deleted) expect(removed4[0].deleted.id).toBe(4);
317
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(true);
318
+ // expect(objTreeMultimap.getHeight()).toBe(4);
319
+ //
320
+ // const removed10 = objTreeMultimap.remove(10, true);
321
+ // expect(removed10).toBeInstanceOf(Array);
322
+ // expect(removed10[0]).toBeDefined();
323
+ // expect(removed10[0].deleted).toBeDefined();
324
+ // if (removed10[0].deleted) expect(removed10[0].deleted.id).toBe(10);
325
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(false);
326
+ // expect(objTreeMultimap.getHeight()).toBe(4);
327
+ //
328
+ // const removed15 = objTreeMultimap.remove(15, true);
329
+ // expect(removed15).toBeInstanceOf(Array);
330
+ // expect(removed15[0]).toBeDefined();
331
+ // expect(removed15[0].deleted).toBeDefined();
332
+ // if (removed15[0].deleted) expect(removed15[0].deleted.id).toBe(15);
333
+ //
334
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(true);
335
+ // expect(objTreeMultimap.getHeight()).toBe(3);
336
+ //
337
+ // const removed5 = objTreeMultimap.remove(5, true);
338
+ // expect(removed5).toBeInstanceOf(Array);
339
+ // expect(removed5[0]).toBeDefined();
340
+ // expect(removed5[0].deleted).toBeDefined();
341
+ // if (removed5[0].deleted) expect(removed5[0].deleted.id).toBe(5);
342
+ //
343
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(true);
344
+ // expect(objTreeMultimap.getHeight()).toBe(3);
345
+ //
346
+ // const removed13 = objTreeMultimap.remove(13, true);
347
+ // expect(removed13).toBeInstanceOf(Array);
348
+ // expect(removed13[0]).toBeDefined();
349
+ // expect(removed13[0].deleted).toBeDefined();
350
+ // if (removed13[0].deleted) expect(removed13[0].deleted.id).toBe(13);
351
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(true);
352
+ // expect(objTreeMultimap.getHeight()).toBe(3);
353
+ //
354
+ // const removed3 = objTreeMultimap.remove(3, true);
355
+ // expect(removed3).toBeInstanceOf(Array);
356
+ // expect(removed3[0]).toBeDefined();
357
+ // expect(removed3[0].deleted).toBeDefined();
358
+ // if (removed3[0].deleted) expect(removed3[0].deleted.id).toBe(3);
359
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(false);
360
+ // expect(objTreeMultimap.getHeight()).toBe(3);
361
+ //
362
+ // const removed8 = objTreeMultimap.remove(8, true);
363
+ // expect(removed8).toBeInstanceOf(Array);
364
+ // expect(removed8[0]).toBeDefined();
365
+ // expect(removed8[0].deleted).toBeDefined();
366
+ // if (removed8[0].deleted) expect(removed8[0].deleted.id).toBe(8);
367
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(true);
368
+ // expect(objTreeMultimap.getHeight()).toBe(3);
369
+ //
370
+ // const removed6 = objTreeMultimap.remove(6, true);
371
+ // expect(removed6).toBeInstanceOf(Array);
372
+ // expect(removed6[0]).toBeDefined();
373
+ // expect(removed6[0].deleted).toBeDefined();
374
+ // if (removed6[0].deleted) expect(removed6[0].deleted.id).toBe(6);
375
+ // expect(objTreeMultimap.remove(6, true).length).toBe(0);
376
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(false);
377
+ // expect(objTreeMultimap.getHeight()).toBe(3);
378
+ //
379
+ // const removed7 = objTreeMultimap.remove(7, true);
380
+ // expect(removed7).toBeInstanceOf(Array);
381
+ // expect(removed7[0]).toBeDefined();
382
+ // expect(removed7[0].deleted).toBeDefined();
383
+ // if (removed7[0].deleted) expect(removed7[0].deleted.id).toBe(7);
384
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(false);
385
+ // expect(objTreeMultimap.getHeight()).toBe(3);
386
+ //
387
+ // const removed9 = objTreeMultimap.remove(9, true);
388
+ // expect(removed9).toBeInstanceOf(Array);
389
+ // expect(removed9[0]).toBeDefined();
390
+ // expect(removed9[0].deleted).toBeDefined();
391
+ // if (removed9[0].deleted) expect(removed9[0].deleted.id).toBe(9);
392
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(false);
393
+ // expect(objTreeMultimap.getHeight()).toBe(3);
394
+ //
395
+ // const removed14 = objTreeMultimap.remove(14, true);
396
+ // expect(removed14).toBeInstanceOf(Array);
397
+ // expect(removed14[0]).toBeDefined();
398
+ // expect(removed14[0].deleted).toBeDefined();
399
+ // if (removed14[0].deleted) expect(removed14[0].deleted.id).toBe(14);
400
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(false);
401
+ // expect(objTreeMultimap.getHeight()).toBe(2);
402
+ //
403
+ //
404
+ // expect(objTreeMultimap.isAVLBalanced()).toBe(false);
405
+ //
406
+ // const bfsIDs = objTreeMultimap.BFS();
407
+ // expect(bfsIDs[0]).toBe(2);
408
+ // expect(bfsIDs[1]).toBe(12);
409
+ // expect(bfsIDs[2]).toBe(16);
410
+ //
411
+ // const bfsNodes = objTreeMultimap.BFS('node');
412
+ // expect(bfsNodes[0].id).toBe(2);
413
+ // expect(bfsNodes[1].id).toBe(12);
414
+ // expect(bfsNodes[2].id).toBe(16);
415
+ //
416
+ // expect(objTreeMultimap.count).toBe(5);
417
+ });
418
+ });
419
+
420
+ describe('TreeMultimap Performance test', function () {
421
+ // const treeMS = new TreeMultimap<TreeMultimapNode<number>>();
422
+ // const inputSizes = [100]; // Adjust input sizes as needed
423
+ //
424
+ // // Define a function to calculate the expected O(n log n) time
425
+ // function expectedTime(n: number): number {
426
+ // return n * Math.log(n);
427
+ // }
428
+
429
+ it(`Observe the time consumption of TreeMultimap.add fitting O(n log n)`, function () {
430
+ // // Create a benchmark suite
431
+ // const suite = new Benchmark.Suite();
432
+ // // Define a function to generate a random array of a given size
433
+ // function generateRandomArray(size: number): number[] {
434
+ // const arr: number[] = [];
435
+ // for (let i = 0; i < size; i++) {
436
+ // arr.push(Math.floor(Math.random() * size));
437
+ // }
438
+ // return arr;
439
+ // }
440
+ // const inputArray = generateRandomArray(inputSizes[0]);
441
+ //
442
+ // suite.add(`TreeMultimap addMany (n=${inputSizes[0]})`, () => {
443
+ // treeMS.addMany([...inputArray]);
444
+ // });
445
+ //
446
+ // // Run the benchmarks
447
+ // suite
448
+ // .on('cycle', (event: any) => {
449
+ // const benchmark = event.target;
450
+ // const n = parseInt(benchmark.name.split('=')[1]);
451
+ // const observedTime = benchmark.times.elapsed;
452
+ // const expected = expectedTime(n);
453
+ // console.log(`Input size (n): ${n}, Observed time: ${observedTime.toFixed(2)}ms, Expected time: ${expected.toFixed(2)}ms`);
454
+ // })
455
+ // .on('complete', () => {
456
+ // console.log(`Benchmark (n=${inputSizes[0]}) completed.`);
457
+ // done(); // Call done to indicate the test is complete
458
+ // })
459
+ // .run({async: true});
460
+ });
461
+ });
package/tsconfig.json ADDED
@@ -0,0 +1,38 @@
1
+ {
2
+ "compilerOptions": {
3
+ "declaration": true,
4
+ "outDir": "./dist",
5
+ "module": "commonjs",
6
+ "target": "es6",
7
+ "lib": [
8
+ // "es2015",
9
+ "esnext"
10
+ ],
11
+ "strict": true,
12
+ "esModuleInterop": true,
13
+ "moduleResolution": "node",
14
+ "declarationDir": "./dist",
15
+ "skipLibCheck": true,
16
+ "downlevelIteration": true,
17
+ "experimentalDecorators": true,
18
+ // "allowJs": true,
19
+ // "allowSyntheticDefaultImports": true,
20
+ // "forceConsistentCasingInFileNames": true,
21
+ // "noFallthroughCasesInSwitch": true,
22
+ // "resolveJsonModule": true,
23
+ // "isolatedModules": true,
24
+ // "noEmit": true,
25
+ "typeRoots": [
26
+ "node_modules/@types"
27
+ ]
28
+ },
29
+ "include": [
30
+ "src"
31
+ ],
32
+ "exclude": [
33
+ // "node_modules/data-structure-typed",
34
+ "node_modules",
35
+ "dist"
36
+ ]
37
+ }
38
+