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,564 +0,0 @@
1
- import {DirectedEdge, DirectedGraph, DirectedVertex, VertexKey} from '../../../../src';
2
-
3
- describe('DirectedGraph Operation Test', () => {
4
- let graph: DirectedGraph;
5
-
6
- beforeEach(() => {
7
- graph = new DirectedGraph();
8
- });
9
-
10
- it('should add vertices', () => {
11
- const vertex1 = new DirectedVertex('A');
12
- const vertex2 = new DirectedVertex('B');
13
-
14
- graph.addVertex(vertex1);
15
- graph.addVertex(vertex2);
16
-
17
- expect(graph.hasVertex(vertex1)).toBe(true);
18
- expect(graph.hasVertex(vertex2)).toBe(true);
19
- });
20
-
21
- it('should add edges', () => {
22
- const vertex1 = new DirectedVertex('A');
23
- const vertex2 = new DirectedVertex('B');
24
- const edge = new DirectedEdge('A', 'B');
25
- edge.src = edge.src;
26
- edge.dest = edge.dest;
27
-
28
- graph.addVertex(vertex1);
29
- graph.addVertex(vertex2);
30
- graph.addEdge(edge);
31
-
32
- expect(graph.outEdgeMap.size).toBe(1);
33
- expect(graph.inEdgeMap.size).toBe(1);
34
- expect(graph.hasEdge('A', 'B')).toBe(true);
35
- expect(graph.hasEdge('B', 'A')).toBe(false);
36
- });
37
-
38
- it('should delete edges', () => {
39
- const vertex1 = new DirectedVertex('A');
40
- // const vertex2 = new DirectedVertex('B');
41
- graph.createVertex('B');
42
- const edge = new DirectedEdge('A', 'B');
43
-
44
- graph.addVertex(vertex1);
45
- graph.addVertex('B');
46
- graph.addEdge(edge);
47
-
48
- expect(graph.deleteEdge(edge)).toBe(edge);
49
- expect(graph.hasEdge('A', 'B')).toBe(false);
50
- });
51
-
52
- it('should perform topological sort', () => {
53
- const vertexA = new DirectedVertex('A');
54
- const vertexB = new DirectedVertex('B');
55
- const vertexC = new DirectedVertex('C');
56
- const edgeAB = new DirectedEdge('A', 'B');
57
- graph.createEdge('B', 'C');
58
-
59
- graph.addVertex(vertexA);
60
- graph.addVertex(vertexB);
61
- graph.addVertex(vertexC);
62
- graph.addEdge(edgeAB);
63
- graph.addEdge('B', 'C');
64
-
65
- expect(graph.getEdgeSrc(edgeAB)).toBe(vertexA);
66
-
67
- const topologicalOrder = graph.topologicalSort();
68
- if (topologicalOrder) expect(topologicalOrder).toEqual(['A', 'B', 'C']);
69
-
70
- graph.deleteEdgesBetween('A', 'B');
71
-
72
- const topologicalOrder1 = graph.topologicalSort();
73
- if (topologicalOrder1) expect(topologicalOrder1).toEqual(['B', 'C', 'A']);
74
-
75
- expect(graph.incomingEdgesOf(vertexC)?.length).toBe(1);
76
- expect(graph.degreeOf(vertexA)).toBe(0);
77
- expect(graph.inDegreeOf(vertexC)).toBe(1);
78
- expect(graph.outDegreeOf(vertexC)).toBe(0);
79
- expect(graph.edgesOf(vertexC)?.length).toBe(1);
80
-
81
- expect(graph.tarjan(true, true, true, true)?.dfnMap.size).toBe(3);
82
- expect(graph.bellmanFord(vertexC, true, true, true)?.paths.length).toBe(3);
83
- expect(graph.getMinPathBetween('B', 'C', true)?.length).toBe(2);
84
- expect(graph.setEdgeWeight('B', 'C', 100)).toBe(true);
85
- expect(graph.getMinCostBetween('B', 'C', true)).toBe(100);
86
- expect(graph.getMinCostBetween('B', 'C')).toBe(1);
87
- expect(graph.getAllPathsBetween('B', 'C')?.length).toBe(1);
88
- expect(graph.deleteVertex(vertexB)).toBe(true);
89
- expect(graph.getAllPathsBetween('B', 'C')?.length).toBe(0);
90
-
91
- expect(graph.removeManyVertices([vertexB, vertexC])).toBe(true);
92
- });
93
- });
94
-
95
- class MyVertex<V = any> extends DirectedVertex<V> {
96
- constructor(key: VertexKey, value?: V) {
97
- super(key, value);
98
- this._data = value;
99
- }
100
-
101
- protected _data: V | undefined;
102
-
103
- get data(): V | undefined {
104
- return this._data;
105
- }
106
-
107
- set data(value: V | undefined) {
108
- this._data = value;
109
- }
110
- }
111
-
112
- class MyEdge<E = any> extends DirectedEdge<E> {
113
- constructor(v1: VertexKey, v2: VertexKey, weight?: number, value?: E) {
114
- super(v1, v2, weight, value);
115
- this._data = value;
116
- }
117
-
118
- protected _data: E | undefined;
119
-
120
- get data(): E | undefined {
121
- return this._data;
122
- }
123
-
124
- set data(value: E | undefined) {
125
- this._data = value;
126
- }
127
- }
128
-
129
- class MyDirectedGraph<
130
- V = any,
131
- E = any,
132
- VO extends MyVertex<V> = MyVertex<V>,
133
- EO extends MyEdge<E> = MyEdge<E>
134
- > extends DirectedGraph<V, E, VO, EO> {
135
- createVertex(key: VertexKey, value: V): VO {
136
- return new MyVertex(key, value) as VO;
137
- }
138
-
139
- createEdge(src: VertexKey, dest: VertexKey, weight?: number, value?: E): EO {
140
- return new MyEdge(src, dest, weight ?? 1, value) as EO;
141
- }
142
-
143
- setInEdgeMap(value: Map<VO, EO[]>) {
144
- this._inEdgeMap = value;
145
- }
146
-
147
- setOutEdgeMap(value: Map<VO, EO[]>) {
148
- this._outEdgeMap = value;
149
- }
150
- }
151
-
152
- describe('Inherit from DirectedGraph and perform operations', () => {
153
- let myGraph = new MyDirectedGraph<string, string>();
154
- beforeEach(() => {
155
- myGraph = new MyDirectedGraph();
156
- });
157
-
158
- it('Add vertices', () => {
159
- myGraph.addVertex(1, 'data1');
160
- myGraph.addVertex(2, 'data2');
161
- myGraph.addVertex(3, 'data3');
162
- myGraph.addVertex(4, 'data4');
163
- myGraph.addVertex(5, 'data5');
164
- myGraph.addVertex(new MyVertex(6, 'data6'));
165
- myGraph.addVertex(new MyVertex(7, 'data7'));
166
- myGraph.addVertex(new MyVertex(8, 'data8'));
167
- myGraph.addVertex(new MyVertex(9, 'data9'));
168
- });
169
-
170
- it('Add edges', () => {
171
- myGraph.addVertex(1, 'data1');
172
- myGraph.addVertex(2, 'data2');
173
- myGraph.addEdge(1, 2, 10, 'edge-data1-2');
174
- myGraph.addEdge(new MyEdge(2, 1, 20, 'edge-data2-1'));
175
- myGraph.setInEdgeMap(myGraph.inEdgeMap);
176
- myGraph.setOutEdgeMap(myGraph.outEdgeMap);
177
-
178
- expect(myGraph.edgeSet().length).toBe(2);
179
- // TODO
180
- expect(myGraph.getEdge(1, 2)).toBeInstanceOf(MyEdge);
181
- expect(myGraph.getEdge(2, 1)).toBeInstanceOf(MyEdge);
182
- });
183
-
184
- it('Get edge', () => {
185
- myGraph.addVertex(1, 'val1');
186
- myGraph.addVertex(2, 'val1');
187
- myGraph.addEdge(1, 2, 1, 'val1');
188
- const edge1 = myGraph.getEdge(1, 2);
189
- const edge2 = myGraph.getEdge(myGraph.getVertex(1), myGraph.getVertex(2));
190
- const edge3 = myGraph.getEdge(1, '100');
191
- // edge1.data has type problem. After the uniform design, the generics of containers (DirectedGraph, BST) are based on the type of value. However, this design has a drawback: when I attempt to inherit from the Vertex or BSTNode classes, the types of the results obtained by all methods are those of the parent class.
192
- expect(edge1).toBeInstanceOf(MyEdge);
193
- if (edge1) {
194
- expect(edge1.data).toBe('val1');
195
- expect(edge1?.value).toBe('val1');
196
- expect(edge1).toBeInstanceOf(MyEdge);
197
- expect(edge1.src).toBe(1);
198
- expect(edge1).toEqual(edge2);
199
- expect(edge3).toBeNull();
200
- }
201
- });
202
-
203
- it('Edge set and vertex set', () => {
204
- expect(true).toBeTruthy();
205
- });
206
-
207
- it('Remove edge between vertices', () => {
208
- myGraph.addVertex(1, 'data1');
209
- myGraph.addVertex(2, 'data2');
210
- myGraph.addEdge(1, 2, 10, 'edge-data1-2');
211
-
212
- const removedEdge = myGraph.deleteEdgeSrcToDest(1, 2);
213
- const edgeAfterRemoval = myGraph.getEdge(1, 2);
214
-
215
- expect(removedEdge).toBeInstanceOf(MyEdge);
216
- if (removedEdge) {
217
- removedEdge && expect(removedEdge.value).toBe('edge-data1-2');
218
- removedEdge && expect(removedEdge.src).toBe(1);
219
- }
220
- expect(edgeAfterRemoval).toBeNull();
221
- });
222
-
223
- it('Topological sort', () => {
224
- const sorted = myGraph.topologicalSort();
225
-
226
- expect(sorted).toBeInstanceOf(Array);
227
- if (sorted && sorted.length > 0) {
228
- expect(sorted.length).toBe(9);
229
- if (sorted[0] instanceof MyVertex) expect(sorted[0].data).toBe('data9');
230
- sorted[3] instanceof MyVertex && expect(sorted[3].data).toBe('data6');
231
- sorted[8] instanceof MyVertex && expect(sorted[8].key).toBe(1);
232
- }
233
- });
234
-
235
- it('Minimum path between vertices', () => {
236
- myGraph.addVertex(new MyVertex(1, 'data1'));
237
- myGraph.addVertex(new MyVertex(2, 'data2'));
238
- myGraph.addEdge(new MyEdge(1, 2, 10, 'edge-data1-2'));
239
- });
240
-
241
- it('All paths between vertices', () => {
242
- // Add vertices and edges as needed for this test
243
- myGraph.addVertex(new MyVertex(1, 'data1'));
244
- myGraph.addVertex(new MyVertex(2, 'data2'));
245
- myGraph.addEdge(new MyEdge(1, 2, 10, 'edge-data1-2'));
246
-
247
- // Add expect statements here to verify the allPaths
248
- });
249
- });
250
-
251
- describe('Inherit from DirectedGraph and perform operations test2.', () => {
252
- const myGraph = new MyDirectedGraph<string, string>();
253
-
254
- it('should test graph operations', () => {
255
- const vertex1 = new MyVertex(1, 'data1');
256
- const vertex2 = new MyVertex(2, 'data2');
257
- const vertex3 = new MyVertex(3, 'data3');
258
- const vertex4 = new MyVertex(4, 'data4');
259
- const vertex5 = new MyVertex(5, 'data5');
260
- const vertex6 = new MyVertex(6, 'data6');
261
- const vertex7 = new MyVertex(7, 'data7');
262
- const vertex8 = new MyVertex(8, 'data8');
263
- const vertex9 = new MyVertex(9, 'data9');
264
- myGraph.addVertex(vertex1);
265
- myGraph.addVertex(vertex2);
266
- myGraph.addVertex(vertex3);
267
- myGraph.addVertex(vertex4);
268
- myGraph.addVertex(vertex5);
269
- myGraph.addVertex(vertex6);
270
- myGraph.addVertex(vertex7);
271
- myGraph.addVertex(vertex8);
272
- myGraph.addVertex(vertex9);
273
-
274
- myGraph.addEdge(new MyEdge(1, 2, 10, 'edge-data1-2'));
275
- myGraph.addEdge(new MyEdge(2, 1, 20, 'edge-data2-1'));
276
-
277
- expect(myGraph.getEdge(1, 2)).toBeTruthy();
278
- expect(myGraph.getEdge(2, 1)).toBeTruthy();
279
- expect(myGraph.getEdge(1, '100')).toBeFalsy();
280
-
281
- myGraph.deleteEdgeSrcToDest(1, 2);
282
- expect(myGraph.getEdge(1, 2)).toBeFalsy();
283
-
284
- myGraph.addEdge(3, 1, 3, 'edge-data-3-1');
285
-
286
- myGraph.addEdge(1, 9, 19, 'edge-data1-9');
287
-
288
- myGraph.addEdge(9, 7, 97, 'edge-data9-7');
289
-
290
- myGraph.addEdge(7, 9, 79, 'edge-data7-9');
291
-
292
- myGraph.addEdge(1, 4, 14, 'edge-data1-4');
293
-
294
- myGraph.addEdge(4, 7, 47, 'edge-data4-7');
295
-
296
- myGraph.addEdge(1, 2, 12, 'edge-data1-2');
297
-
298
- myGraph.addEdge(2, 3, 23, 'edge-data2-3');
299
-
300
- myGraph.addEdge(3, 5, 35, 'edge-data3-5');
301
-
302
- myGraph.addEdge(5, 7, 57, 'edge-data5-7');
303
-
304
- myGraph.addEdge(new MyEdge(7, 3, 73, 'edge-data7-3'));
305
- const topologicalSorted = myGraph.topologicalSort();
306
- expect(topologicalSorted).toBeNull();
307
-
308
- const minPath1to7 = myGraph.getMinPathBetween(1, 7);
309
-
310
- expect(minPath1to7).toBeInstanceOf(Array);
311
- if (minPath1to7 && minPath1to7.length > 0) {
312
- expect(minPath1to7).toHaveLength(3);
313
- expect(minPath1to7[0]).toBeInstanceOf(MyVertex);
314
- expect(minPath1to7[0].key).toBe(1);
315
- expect(minPath1to7[1].key).toBe(9);
316
- expect(minPath1to7[2].key).toBe(7);
317
- }
318
-
319
- const fordResult1 = myGraph.bellmanFord(1);
320
- expect(fordResult1).toBeTruthy();
321
- expect(fordResult1.hasNegativeCycle).toBeUndefined();
322
- const {distMap, preMap, paths, min, minPath} = fordResult1;
323
- expect(distMap).toBeInstanceOf(Map);
324
- expect(distMap.size).toBe(9);
325
- expect(distMap.get(vertex1)).toBe(0);
326
- expect(distMap.get(vertex2)).toBe(12);
327
- expect(distMap.get(vertex3)).toBe(35);
328
- expect(distMap.get(vertex4)).toBe(14);
329
- expect(distMap.get(vertex5)).toBe(70);
330
- expect(distMap.get(vertex6)).toBe(Infinity);
331
- expect(distMap.get(vertex7)).toBe(61);
332
- expect(distMap.get(vertex8)).toBe(Infinity);
333
- expect(distMap.get(vertex9)).toBe(19);
334
-
335
- expect(preMap).toBeInstanceOf(Map);
336
- expect(preMap.size).toBe(0);
337
-
338
- expect(paths).toBeInstanceOf(Array);
339
- expect(paths.length).toBe(0);
340
- expect(min).toBe(Infinity);
341
- expect(minPath).toBeInstanceOf(Array);
342
-
343
- const floydResult = myGraph.floyd();
344
- expect(floydResult).toBeTruthy();
345
- if (floydResult) {
346
- const {costs, predecessor} = floydResult;
347
- expect(costs).toBeInstanceOf(Array);
348
- expect(costs.length).toBe(9);
349
- expect(costs[0]).toEqual([32, 12, 35, 14, 70, Infinity, 61, Infinity, 19]);
350
- expect(costs[1]).toEqual([20, 32, 23, 34, 58, Infinity, 81, Infinity, 39]);
351
- expect(costs[2]).toEqual([3, 15, 38, 17, 35, Infinity, 64, Infinity, 22]);
352
- expect(costs[3]).toEqual([123, 135, 120, 137, 155, Infinity, 47, Infinity, 126]);
353
- expect(costs[4]).toEqual([133, 145, 130, 147, 165, Infinity, 57, Infinity, 136]);
354
- expect(costs[5]).toEqual([
355
- Infinity,
356
- Infinity,
357
- Infinity,
358
- Infinity,
359
- Infinity,
360
- Infinity,
361
- Infinity,
362
- Infinity,
363
- Infinity
364
- ]);
365
- expect(costs[6]).toEqual([76, 88, 73, 90, 108, Infinity, 137, Infinity, 79]);
366
- expect(costs[7]).toEqual([
367
- Infinity,
368
- Infinity,
369
- Infinity,
370
- Infinity,
371
- Infinity,
372
- Infinity,
373
- Infinity,
374
- Infinity,
375
- Infinity
376
- ]);
377
- expect(costs[8]).toEqual([173, 185, 170, 187, 205, Infinity, 97, Infinity, 176]);
378
-
379
- expect(predecessor).toBeInstanceOf(Array);
380
- expect(predecessor.length).toBe(9);
381
- expect(predecessor[0]).toEqual([vertex2, null, vertex2, null, vertex3, null, vertex4, null, null]);
382
- expect(predecessor[1]).toEqual([null, vertex1, null, vertex1, vertex3, null, vertex4, null, vertex1]);
383
- expect(predecessor[5]).toEqual([null, null, null, null, null, null, null, null, null]);
384
- expect(predecessor[7]).toEqual([null, null, null, null, null, null, null, null, null]);
385
- expect(predecessor[8]).toEqual([vertex7, vertex7, vertex7, vertex7, vertex7, null, null, null, vertex7]);
386
- }
387
-
388
- const dijkstraRes12tt = myGraph.dijkstra(1, 2, true, true);
389
-
390
- expect(dijkstraRes12tt).toBeTruthy();
391
- if (dijkstraRes12tt) {
392
- const {distMap, minDist, minPath, paths} = dijkstraRes12tt;
393
- expect(distMap).toBeInstanceOf(Map);
394
- expect(distMap.size).toBe(9);
395
- expect(distMap.get(vertex1)).toBe(0);
396
- expect(distMap.get(vertex2)).toBe(12);
397
- expect(distMap.get(vertex3)).toBe(Infinity);
398
- expect(distMap.get(vertex4)).toBe(14);
399
- expect(distMap.get(vertex5)).toBe(Infinity);
400
- expect(distMap.get(vertex6)).toBe(Infinity);
401
- expect(distMap.get(vertex7)).toBe(Infinity);
402
- expect(distMap.get(vertex8)).toBe(Infinity);
403
- expect(distMap.get(vertex9)).toBe(19);
404
-
405
- expect(minDist).toBe(12);
406
- expect(minPath).toBeInstanceOf(Array);
407
- expect(minPath.length).toBe(2);
408
- expect(minPath[0]).toBe(vertex1);
409
- expect(minPath[1]).toBe(vertex2);
410
-
411
- expect(paths).toBeInstanceOf(Array);
412
- expect(paths.length).toBe(9);
413
- expect(paths[0]).toBeInstanceOf(Array);
414
- expect(paths[0][0]).toBe(vertex1);
415
-
416
- expect(paths[1]).toBeInstanceOf(Array);
417
- expect(paths[1][0]).toBe(vertex1);
418
- expect(paths[1][1]).toBe(vertex2);
419
-
420
- expect(paths[2]).toBeInstanceOf(Array);
421
- expect(paths[2][0]).toBe(vertex3);
422
- expect(paths[3]).toBeInstanceOf(Array);
423
- expect(paths[3][0]).toBe(vertex1);
424
- expect(paths[3][1]).toBe(vertex4);
425
- expect(paths[4]).toBeInstanceOf(Array);
426
- expect(paths[4][0]).toBe(vertex5);
427
-
428
- expect(paths[5]).toBeInstanceOf(Array);
429
- expect(paths[5][0]).toBe(vertex6);
430
- expect(paths[6]).toBeInstanceOf(Array);
431
- expect(paths[6][0]).toBe(vertex7);
432
- expect(paths[7]).toBeInstanceOf(Array);
433
- expect(paths[7][0]).toBe(vertex8);
434
- expect(paths[8]).toBeInstanceOf(Array);
435
- expect(paths[8][0]).toBe(vertex1);
436
- expect(paths[8][1]).toBe(vertex9);
437
- }
438
-
439
- const dijkstraRes1ntt = myGraph.dijkstra(1, null, true, true);
440
-
441
- expect(dijkstraRes1ntt).toBeTruthy();
442
- if (dijkstraRes1ntt) {
443
- const {distMap, minDist, minPath, paths} = dijkstraRes1ntt;
444
- expect(distMap).toBeInstanceOf(Map);
445
- expect(distMap.size).toBe(9);
446
- expect(distMap.get(vertex1)).toBe(0);
447
- expect(distMap.get(vertex2)).toBe(12);
448
- expect(distMap.get(vertex3)).toBe(35);
449
- expect(distMap.get(vertex4)).toBe(14);
450
- expect(distMap.get(vertex5)).toBe(70);
451
- expect(distMap.get(vertex6)).toBe(Infinity);
452
- expect(distMap.get(vertex7)).toBe(61);
453
- expect(distMap.get(vertex8)).toBe(Infinity);
454
- expect(distMap.get(vertex9)).toBe(19);
455
-
456
- expect(minDist).toBe(12);
457
- expect(minPath).toBeInstanceOf(Array);
458
- expect(minPath.length).toBe(2);
459
- expect(minPath[0]).toBe(vertex1);
460
- expect(minPath[1]).toBe(vertex2);
461
-
462
- expect(paths).toBeInstanceOf(Array);
463
- expect(paths.length).toBe(9);
464
- expect(paths[0]).toBeInstanceOf(Array);
465
- expect(paths[0][0]).toBe(vertex1);
466
-
467
- expect(paths[1]).toBeInstanceOf(Array);
468
- expect(paths[1][0]).toBe(vertex1);
469
- expect(paths[1][1]).toBe(vertex2);
470
-
471
- expect(paths[2]).toBeInstanceOf(Array);
472
- expect(paths[2][0]).toBe(vertex1);
473
- expect(paths[2][1]).toBe(vertex2);
474
- expect(paths[2][2]).toBe(vertex3);
475
-
476
- expect(paths[3]).toBeInstanceOf(Array);
477
- expect(paths[3][0]).toBe(vertex1);
478
- expect(paths[3][1]).toBe(vertex4);
479
-
480
- expect(paths[4]).toBeInstanceOf(Array);
481
- expect(paths[4][0]).toBe(vertex1);
482
- expect(paths[4][1]).toBe(vertex2);
483
- expect(paths[4][2]).toBe(vertex3);
484
- expect(paths[4][3]).toBe(vertex5);
485
-
486
- expect(paths[5]).toBeInstanceOf(Array);
487
- expect(paths[5][0]).toBe(vertex6);
488
-
489
- expect(paths[6]).toBeInstanceOf(Array);
490
- expect(paths[6][0]).toBe(vertex1);
491
- expect(paths[6][1]).toBe(vertex4);
492
- expect(paths[6][2]).toBe(vertex7);
493
-
494
- expect(paths[7]).toBeInstanceOf(Array);
495
- expect(paths[7][0]).toBe(vertex8);
496
-
497
- expect(paths[8]).toBeInstanceOf(Array);
498
- expect(paths[8][0]).toBe(vertex1);
499
- expect(paths[8][1]).toBe(vertex9);
500
- }
501
-
502
- const dijkstraWithoutHeapRes1ntt = myGraph.dijkstraWithoutHeap(1, null, true, true);
503
- expect(dijkstraWithoutHeapRes1ntt).toBeTruthy();
504
- if (dijkstraWithoutHeapRes1ntt) {
505
- const {distMap, minDist, minPath, paths} = dijkstraWithoutHeapRes1ntt;
506
- expect(distMap).toBeInstanceOf(Map);
507
- expect(distMap.size).toBe(9);
508
- expect(distMap.get(vertex1)).toBe(0);
509
- expect(distMap.get(vertex2)).toBe(12);
510
- expect(distMap.get(vertex3)).toBe(35);
511
- expect(distMap.get(vertex4)).toBe(14);
512
- expect(distMap.get(vertex5)).toBe(70);
513
- expect(distMap.get(vertex6)).toBe(Infinity);
514
- expect(distMap.get(vertex7)).toBe(61);
515
- expect(distMap.get(vertex8)).toBe(Infinity);
516
- expect(distMap.get(vertex9)).toBe(19);
517
-
518
- expect(minDist).toBe(12);
519
- expect(minPath).toBeInstanceOf(Array);
520
- expect(minPath.length).toBe(2);
521
- expect(minPath[0]).toBe(vertex1);
522
- expect(minPath[1]).toBe(vertex2);
523
-
524
- expect(paths).toBeInstanceOf(Array);
525
- expect(paths.length).toBe(9);
526
- expect(paths[0]).toBeInstanceOf(Array);
527
- expect(paths[0][0]).toBe(vertex1);
528
-
529
- expect(paths[1]).toBeInstanceOf(Array);
530
- expect(paths[1][0]).toBe(vertex1);
531
- expect(paths[1][1]).toBe(vertex2);
532
-
533
- expect(paths[2]).toBeInstanceOf(Array);
534
- expect(paths[2][0]).toBe(vertex1);
535
- expect(paths[2][1]).toBe(vertex2);
536
- expect(paths[2][2]).toBe(vertex3);
537
-
538
- expect(paths[3]).toBeInstanceOf(Array);
539
- expect(paths[3][0]).toBe(vertex1);
540
- expect(paths[3][1]).toBe(vertex4);
541
-
542
- expect(paths[4]).toBeInstanceOf(Array);
543
- expect(paths[4][0]).toBe(vertex1);
544
- expect(paths[4][1]).toBe(vertex2);
545
- expect(paths[4][2]).toBe(vertex3);
546
- expect(paths[4][3]).toBe(vertex5);
547
-
548
- expect(paths[5]).toBeInstanceOf(Array);
549
- expect(paths[5][0]).toBe(vertex6);
550
-
551
- expect(paths[6]).toBeInstanceOf(Array);
552
- expect(paths[6][0]).toBe(vertex1);
553
- expect(paths[6][1]).toBe(vertex4);
554
- expect(paths[6][2]).toBe(vertex7);
555
-
556
- expect(paths[7]).toBeInstanceOf(Array);
557
- expect(paths[7][0]).toBe(vertex8);
558
-
559
- expect(paths[8]).toBeInstanceOf(Array);
560
- expect(paths[8][0]).toBe(vertex1);
561
- expect(paths[8][1]).toBe(vertex9);
562
- }
563
- });
564
- });
@@ -1,126 +0,0 @@
1
- import {MapEdge, MapGraph, MapVertex} from '../../../../src';
2
-
3
- describe('MapGraph Operation Test', () => {
4
- it('dijkstra shortest path', () => {
5
- const mapGraph = new MapGraph([5.500338, 100.173665]);
6
-
7
- mapGraph.addVertex(new MapVertex('Surin', '', 5.466724, 100.274805));
8
- mapGraph.addVertex(new MapVertex('Batu Feringgi Beach', '', 5.475141, 100.27667));
9
- mapGraph.addVertex(new MapVertex('Lotus', '', 5.459044, 100.308767));
10
- mapGraph.addVertex(new MapVertex('The Breeza', '', 5.454197, 100.307859));
11
- mapGraph.addVertex(new MapVertex('Hard Rock Hotel', '', 5.46785, 100.241876));
12
- mapGraph.addVertex(new MapVertex('Mira', '', 5.456749, 100.28665));
13
- mapGraph.addVertex(new MapVertex('Penang Bible Church', '', 5.428683, 100.314825));
14
- mapGraph.addVertex(new MapVertex('Queensbay', '', 5.33276, 100.306651));
15
- mapGraph.addVertex(new MapVertex('Saanen Goat Farm', '', 5.405738, 100.207699));
16
- mapGraph.addVertex(new MapVertex('Trinity Auto', '', 5.401126, 100.303739));
17
- mapGraph.addVertex(new MapVertex('Penang Airport', '', 5.293185, 100.265772));
18
- mapGraph.addEdge('Surin', 'Lotus', 4.7);
19
- mapGraph.addEdge('Lotus', 'The Breeza', 1);
20
- mapGraph.addEdge('Batu Feringgi Beach', 'Hard Rock Hotel', 5.2);
21
- mapGraph.addEdge('Surin', 'Mira', 2.8);
22
- mapGraph.addEdge('Mira', 'Penang Bible Church', 7.0);
23
- mapGraph.addEdge('Lotus', 'Penang Bible Church', 5.7);
24
- mapGraph.addEdge('Penang Bible Church', 'Queensbay', 13.9);
25
- mapGraph.addEdge('Hard Rock Hotel', 'Saanen Goat Farm', 18.5);
26
- mapGraph.addEdge('The Breeza', 'Trinity Auto', 9.1);
27
- mapGraph.addEdge('Trinity Auto', 'Saanen Goat Farm', 26.3);
28
- mapGraph.addEdge('The Breeza', 'Penang Airport', 24.8);
29
- mapGraph.addEdge('Penang Airport', 'Saanen Goat Farm', 21.2);
30
- const expected1 = ['Surin', 'Lotus', 'The Breeza', 'Trinity Auto', 'Saanen Goat Farm'];
31
-
32
- const minPathBetween = mapGraph.getMinPathBetween('Surin', 'Saanen Goat Farm');
33
- expect(minPathBetween?.map(v => v.key)).toEqual(expected1);
34
- const surinToSaanenGoatFarmDij = mapGraph.dijkstra('Surin', 'Saanen Goat Farm', true, true);
35
- expect(surinToSaanenGoatFarmDij?.minPath.map(v => v.key)).toEqual(expected1);
36
- expect(surinToSaanenGoatFarmDij?.minDist).toBe(41.1);
37
- mapGraph.addEdge('Surin', 'Batu Feringgi Beach', 1.5);
38
- const expected2 = ['Surin', 'Batu Feringgi Beach', 'Hard Rock Hotel', 'Saanen Goat Farm'];
39
- const minPathBetweenViaBFB = mapGraph.getMinPathBetween('Surin', 'Saanen Goat Farm', true);
40
- expect(minPathBetweenViaBFB?.map(v => v.key)).toEqual(expected2);
41
- const surinToSaanenGoatFarmViaDij = mapGraph.dijkstra('Surin', 'Saanen Goat Farm', true, true);
42
- expect(surinToSaanenGoatFarmViaDij?.minPath.map(v => v.key)).toEqual(expected2);
43
- expect(surinToSaanenGoatFarmViaDij?.minDist).toBe(25.2);
44
- });
45
- });
46
-
47
- describe('MapGraph', () => {
48
- let mapGraph: MapGraph<string, string>;
49
-
50
- beforeEach(() => {
51
- // Create a new MapGraph instance before each test
52
- mapGraph = new MapGraph<string, string>([0, 0], [100, 100]);
53
- });
54
-
55
- // Test adding vertices to the graph
56
- it('should add vertices to the graph', () => {
57
- const locationA = new MapVertex('A', 'Location A', 10, 20);
58
- const locationB = new MapVertex('B', 'Location B', 30, 40);
59
-
60
- mapGraph.addVertex(locationA);
61
- mapGraph.addVertex(locationB);
62
-
63
- expect(mapGraph.hasVertex('A')).toBe(true);
64
- expect(mapGraph.hasVertex('B')).toBe(true);
65
- });
66
-
67
- // Test adding edges to the graph
68
- it('should add edges to the graph', () => {
69
- const locationA = new MapVertex('A', 'Location A', 10, 20);
70
- const locationB = new MapVertex('B', 'Location B', 30, 40);
71
- const edgeAB = new MapEdge('A', 'B', 50, 'Edge from A to B');
72
-
73
- mapGraph.addVertex(locationA);
74
- mapGraph.addVertex(locationB);
75
- mapGraph.addEdge(edgeAB);
76
-
77
- expect(mapGraph.hasEdge('A', 'B')).toBe(true);
78
- });
79
-
80
- // Test getting neighbors of a vertex
81
- it('should return the neighbors of a vertex', () => {
82
- const locationA = new MapVertex('A', 'Location A', 10, 20);
83
- locationA.lat = locationA.lat;
84
- locationA.long = locationA.long;
85
- const locationB = mapGraph.createVertex('B', 'Location B', 30, 40);
86
-
87
- const locationC = new MapVertex('C', 'Location C', 50, 60);
88
- const edgeAB = new MapEdge('A', 'B', 50, 'Edge from A to B');
89
- const edgeBC = new MapEdge('B', 'C', 60, 'Edge from B to C');
90
-
91
- expect(mapGraph.origin).toEqual([0, 0]);
92
- expect(mapGraph.bottomRight).toEqual([100, 100]);
93
-
94
- mapGraph.addVertex(locationA);
95
- mapGraph.addVertex(locationB);
96
- mapGraph.addVertex(locationC);
97
- mapGraph.addEdge(edgeAB);
98
- mapGraph.addEdge(edgeBC);
99
-
100
- const neighborsOfA = mapGraph.getNeighbors('A');
101
- const neighborsOfB = mapGraph.getNeighbors('B');
102
-
103
- expect(neighborsOfA).toEqual([locationB]);
104
- expect(neighborsOfB).toEqual([locationC]);
105
- });
106
-
107
- // Test finding the shortest path between locations
108
- it('should find the shortest path between two locations', () => {
109
- const locationA = new MapVertex('A', 'Location A', 10, 20);
110
- const locationB = new MapVertex('B', 'Location B', 30, 40);
111
- const locationC = new MapVertex('C', 'Location C', 50, 60);
112
- const edgeAB = new MapEdge('A', 'B', 50, 'Edge from A to B');
113
- const edgeBC = new MapEdge('B', 'C', 60, 'Edge from B to C');
114
-
115
- mapGraph.addVertex(locationA);
116
- mapGraph.addVertex(locationB);
117
- mapGraph.addVertex(locationC);
118
- mapGraph.addEdge(edgeAB);
119
- mapGraph.addEdge(edgeBC);
120
-
121
- const shortestPath = mapGraph.dijkstra('A', 'C');
122
-
123
- expect(shortestPath?.minPath.length).toEqual(0);
124
- expect(shortestPath?.distMap.size).toBe(3);
125
- });
126
- });