data-structure-typed 1.35.1 → 1.40.0-rc

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 (163) hide show
  1. package/dist/data-structures/binary-tree/aa-tree.d.ts +2 -0
  2. package/dist/data-structures/binary-tree/abstract-binary-tree.d.ts +527 -0
  3. package/dist/data-structures/binary-tree/abstract-binary-tree.js +323 -0
  4. package/dist/data-structures/binary-tree/abstract-binary-tree.js.map +1 -1
  5. package/dist/data-structures/binary-tree/avl-tree.d.ts +94 -0
  6. package/dist/data-structures/binary-tree/avl-tree.js +90 -3
  7. package/dist/data-structures/binary-tree/avl-tree.js.map +1 -1
  8. package/dist/data-structures/binary-tree/b-tree.d.ts +2 -0
  9. package/dist/data-structures/binary-tree/binary-indexed-tree.d.ts +46 -0
  10. package/dist/data-structures/binary-tree/binary-indexed-tree.js +36 -0
  11. package/dist/data-structures/binary-tree/binary-indexed-tree.js.map +1 -1
  12. package/dist/data-structures/binary-tree/binary-tree.d.ts +31 -0
  13. package/dist/data-structures/binary-tree/binary-tree.js +21 -0
  14. package/dist/data-structures/binary-tree/binary-tree.js.map +1 -1
  15. package/dist/data-structures/binary-tree/bst.d.ts +133 -0
  16. package/dist/data-structures/binary-tree/bst.js +114 -0
  17. package/dist/data-structures/binary-tree/bst.js.map +1 -1
  18. package/dist/data-structures/binary-tree/index.d.ts +12 -0
  19. package/dist/data-structures/binary-tree/rb-tree.d.ts +13 -0
  20. package/dist/data-structures/binary-tree/segment-tree.d.ts +83 -0
  21. package/dist/data-structures/binary-tree/segment-tree.js +45 -0
  22. package/dist/data-structures/binary-tree/segment-tree.js.map +1 -1
  23. package/dist/data-structures/binary-tree/splay-tree.d.ts +2 -0
  24. package/dist/data-structures/binary-tree/tree-multiset.d.ts +209 -0
  25. package/dist/data-structures/binary-tree/tree-multiset.js +178 -0
  26. package/dist/data-structures/binary-tree/tree-multiset.js.map +1 -1
  27. package/dist/data-structures/binary-tree/two-three-tree.d.ts +2 -0
  28. package/dist/data-structures/graph/abstract-graph.d.ts +332 -0
  29. package/dist/data-structures/graph/abstract-graph.js +269 -4
  30. package/dist/data-structures/graph/abstract-graph.js.map +1 -1
  31. package/dist/data-structures/graph/directed-graph.d.ts +200 -0
  32. package/dist/data-structures/graph/directed-graph.js +167 -0
  33. package/dist/data-structures/graph/directed-graph.js.map +1 -1
  34. package/dist/data-structures/graph/index.d.ts +4 -0
  35. package/dist/data-structures/graph/map-graph.d.ts +79 -0
  36. package/dist/data-structures/graph/map-graph.js +54 -0
  37. package/dist/data-structures/graph/map-graph.js.map +1 -1
  38. package/dist/data-structures/graph/undirected-graph.d.ts +127 -0
  39. package/dist/data-structures/graph/undirected-graph.js +105 -0
  40. package/dist/data-structures/graph/undirected-graph.js.map +1 -1
  41. package/dist/data-structures/hash/coordinate-map.d.ts +45 -0
  42. package/dist/data-structures/hash/coordinate-map.js +35 -0
  43. package/dist/data-structures/hash/coordinate-map.js.map +1 -1
  44. package/dist/data-structures/hash/coordinate-set.d.ts +37 -0
  45. package/dist/data-structures/hash/coordinate-set.js +28 -0
  46. package/dist/data-structures/hash/coordinate-set.js.map +1 -1
  47. package/dist/data-structures/hash/hash-map.d.ts +56 -0
  48. package/dist/data-structures/hash/hash-map.js +29 -1
  49. package/dist/data-structures/hash/hash-map.js.map +1 -1
  50. package/dist/data-structures/hash/hash-table.d.ts +106 -0
  51. package/dist/data-structures/hash/hash-table.js +88 -6
  52. package/dist/data-structures/hash/hash-table.js.map +1 -1
  53. package/dist/data-structures/hash/index.d.ts +7 -0
  54. package/dist/data-structures/hash/pair.d.ts +2 -0
  55. package/dist/data-structures/hash/tree-map.d.ts +2 -0
  56. package/dist/data-structures/hash/tree-set.d.ts +2 -0
  57. package/dist/data-structures/heap/heap.d.ts +83 -0
  58. package/dist/data-structures/heap/heap.js +62 -0
  59. package/dist/data-structures/heap/heap.js.map +1 -1
  60. package/dist/data-structures/heap/index.d.ts +3 -0
  61. package/dist/data-structures/heap/max-heap.d.ts +23 -0
  62. package/dist/data-structures/heap/max-heap.js +16 -0
  63. package/dist/data-structures/heap/max-heap.js.map +1 -1
  64. package/dist/data-structures/heap/min-heap.d.ts +24 -0
  65. package/dist/data-structures/heap/min-heap.js +17 -0
  66. package/dist/data-structures/heap/min-heap.js.map +1 -1
  67. package/dist/data-structures/index.d.ts +11 -0
  68. package/dist/data-structures/linked-list/doubly-linked-list.d.ts +234 -0
  69. package/dist/data-structures/linked-list/doubly-linked-list.js +202 -0
  70. package/dist/data-structures/linked-list/doubly-linked-list.js.map +1 -1
  71. package/dist/data-structures/linked-list/index.d.ts +3 -0
  72. package/dist/data-structures/linked-list/singly-linked-list.d.ts +157 -0
  73. package/dist/data-structures/linked-list/singly-linked-list.js +135 -0
  74. package/dist/data-structures/linked-list/singly-linked-list.js.map +1 -1
  75. package/dist/data-structures/linked-list/skip-linked-list.d.ts +61 -0
  76. package/dist/data-structures/linked-list/skip-linked-list.js +36 -0
  77. package/dist/data-structures/linked-list/skip-linked-list.js.map +1 -1
  78. package/dist/data-structures/matrix/index.d.ts +4 -0
  79. package/dist/data-structures/matrix/matrix.d.ts +21 -0
  80. package/dist/data-structures/matrix/matrix.js +15 -0
  81. package/dist/data-structures/matrix/matrix.js.map +1 -1
  82. package/dist/data-structures/matrix/matrix2d.d.ts +108 -0
  83. package/dist/data-structures/matrix/matrix2d.js +91 -2
  84. package/dist/data-structures/matrix/matrix2d.js.map +1 -1
  85. package/dist/data-structures/matrix/navigator.d.ts +52 -0
  86. package/dist/data-structures/matrix/navigator.js +28 -0
  87. package/dist/data-structures/matrix/navigator.js.map +1 -1
  88. package/dist/data-structures/matrix/vector2d.d.ts +201 -0
  89. package/dist/data-structures/matrix/vector2d.js +188 -1
  90. package/dist/data-structures/matrix/vector2d.js.map +1 -1
  91. package/dist/data-structures/priority-queue/index.d.ts +3 -0
  92. package/dist/data-structures/priority-queue/max-priority-queue.d.ts +15 -0
  93. package/dist/data-structures/priority-queue/max-priority-queue.js +18 -0
  94. package/dist/data-structures/priority-queue/max-priority-queue.js.map +1 -1
  95. package/dist/data-structures/priority-queue/min-priority-queue.d.ts +15 -0
  96. package/dist/data-structures/priority-queue/min-priority-queue.js +19 -0
  97. package/dist/data-structures/priority-queue/min-priority-queue.js.map +1 -1
  98. package/dist/data-structures/priority-queue/priority-queue.d.ts +180 -0
  99. package/dist/data-structures/priority-queue/priority-queue.js +141 -0
  100. package/dist/data-structures/priority-queue/priority-queue.js.map +1 -1
  101. package/dist/data-structures/queue/deque.d.ts +165 -0
  102. package/dist/data-structures/queue/deque.js +124 -0
  103. package/dist/data-structures/queue/deque.js.map +1 -1
  104. package/dist/data-structures/queue/index.d.ts +2 -0
  105. package/dist/data-structures/queue/queue.d.ts +107 -0
  106. package/dist/data-structures/queue/queue.js +80 -0
  107. package/dist/data-structures/queue/queue.js.map +1 -1
  108. package/dist/data-structures/stack/index.d.ts +1 -0
  109. package/dist/data-structures/stack/stack.d.ts +63 -0
  110. package/dist/data-structures/stack/stack.js +50 -0
  111. package/dist/data-structures/stack/stack.js.map +1 -1
  112. package/dist/data-structures/tree/index.d.ts +1 -0
  113. package/dist/data-structures/tree/tree.d.ts +14 -0
  114. package/dist/data-structures/tree/tree.js +1 -0
  115. package/dist/data-structures/tree/tree.js.map +1 -1
  116. package/dist/data-structures/trie/index.d.ts +1 -0
  117. package/dist/data-structures/trie/trie.d.ts +61 -0
  118. package/dist/data-structures/trie/trie.js +36 -0
  119. package/dist/data-structures/trie/trie.js.map +1 -1
  120. package/dist/index.d.ts +4 -0
  121. package/dist/interfaces/abstract-binary-tree.d.ts +7 -0
  122. package/dist/interfaces/abstract-graph.d.ts +5 -0
  123. package/dist/interfaces/avl-tree.d.ts +7 -0
  124. package/dist/interfaces/binary-tree.d.ts +6 -0
  125. package/dist/interfaces/bst.d.ts +6 -0
  126. package/dist/interfaces/directed-graph.d.ts +3 -0
  127. package/dist/interfaces/doubly-linked-list.d.ts +1 -0
  128. package/dist/interfaces/heap.d.ts +1 -0
  129. package/dist/interfaces/index.d.ts +15 -0
  130. package/dist/interfaces/navigator.d.ts +1 -0
  131. package/dist/interfaces/priority-queue.d.ts +1 -0
  132. package/dist/interfaces/rb-tree.d.ts +6 -0
  133. package/dist/interfaces/segment-tree.d.ts +1 -0
  134. package/dist/interfaces/singly-linked-list.d.ts +1 -0
  135. package/dist/interfaces/tree-multiset.d.ts +6 -0
  136. package/dist/interfaces/undirected-graph.d.ts +3 -0
  137. package/dist/types/data-structures/abstract-binary-tree.d.ts +34 -0
  138. package/dist/types/data-structures/abstract-binary-tree.js +6 -0
  139. package/dist/types/data-structures/abstract-binary-tree.js.map +1 -1
  140. package/dist/types/data-structures/abstract-graph.d.ts +11 -0
  141. package/dist/types/data-structures/avl-tree.d.ts +4 -0
  142. package/dist/types/data-structures/binary-tree.d.ts +4 -0
  143. package/dist/types/data-structures/bst.d.ts +13 -0
  144. package/dist/types/data-structures/directed-graph.d.ts +6 -0
  145. package/dist/types/data-structures/doubly-linked-list.d.ts +1 -0
  146. package/dist/types/data-structures/hash.d.ts +1 -0
  147. package/dist/types/data-structures/heap.d.ts +3 -0
  148. package/dist/types/data-structures/index.d.ts +16 -0
  149. package/dist/types/data-structures/map-graph.d.ts +1 -0
  150. package/dist/types/data-structures/navigator.d.ts +14 -0
  151. package/dist/types/data-structures/priority-queue.d.ts +7 -0
  152. package/dist/types/data-structures/rb-tree.d.ts +8 -0
  153. package/dist/types/data-structures/segment-tree.d.ts +1 -0
  154. package/dist/types/data-structures/singly-linked-list.d.ts +1 -0
  155. package/dist/types/data-structures/tree-multiset.d.ts +4 -0
  156. package/dist/types/helpers.d.ts +1 -0
  157. package/dist/types/index.d.ts +3 -0
  158. package/dist/types/utils/index.d.ts +2 -0
  159. package/dist/types/utils/utils.d.ts +7 -0
  160. package/dist/types/utils/validate-type.d.ts +19 -0
  161. package/dist/utils/index.d.ts +1 -0
  162. package/dist/utils/utils.d.ts +19 -0
  163. package/package.json +10 -6
@@ -0,0 +1,19 @@
1
+ export type KeyValueObject = {
2
+ [key: string]: any;
3
+ };
4
+ export type KeyValueObjectWithKey = {
5
+ [key: string]: any;
6
+ key: string | number | symbol;
7
+ };
8
+ export type NonNumberNonObjectButDefined = string | boolean | symbol | null;
9
+ export type ObjectWithoutKey = Omit<KeyValueObject, 'key'>;
10
+ export type ObjectWithNonNumberKey = {
11
+ [key: string]: any;
12
+ key: string | boolean | symbol | null | object | undefined;
13
+ };
14
+ export type ObjectWithNumberKey = {
15
+ [key: string]: any;
16
+ key: number;
17
+ };
18
+ export type RestrictValByKey = NonNumberNonObjectButDefined | ObjectWithoutKey | ObjectWithNonNumberKey | ObjectWithNumberKey;
19
+ export type DummyAny = string | number | boolean | null | undefined | object | symbol | void | ((...args: []) => any) | never;
@@ -0,0 +1 @@
1
+ export * from './utils';
@@ -0,0 +1,19 @@
1
+ /**
2
+ * data-structure-typed
3
+ *
4
+ * @author Tyler Zeng
5
+ * @copyright Copyright (c) 2022 Tyler Zeng <zrwusa@gmail.com>
6
+ * @license MIT License
7
+ */
8
+ import type { Thunk, ToThunkFn, TrlAsyncFn, TrlFn } from '../types';
9
+ export declare const uuidV4: () => string;
10
+ export declare const arrayRemove: <T>(array: T[], predicate: (item: T, index: number, array: T[]) => boolean) => T[];
11
+ export declare const THUNK_SYMBOL: unique symbol;
12
+ export declare const isThunk: (fnOrValue: any) => boolean;
13
+ export declare const toThunk: (fn: ToThunkFn) => Thunk;
14
+ export declare const trampoline: (fn: TrlFn) => ((...args: [...Parameters<TrlFn>]) => any) & {
15
+ cont: (...args: [...Parameters<TrlFn>]) => Thunk;
16
+ };
17
+ export declare const trampolineAsync: (fn: TrlAsyncFn) => ((...args: [...Parameters<TrlAsyncFn>]) => Promise<any>) & {
18
+ cont: (...args: [...Parameters<TrlAsyncFn>]) => Thunk;
19
+ };
package/package.json CHANGED
@@ -1,12 +1,16 @@
1
1
  {
2
2
  "name": "data-structure-typed",
3
- "version": "1.35.1",
3
+ "version": "1.40.0-rc",
4
4
  "description": "Data Structures of Javascript & TypeScript. Binary Tree, BST, Graph, Heap, Priority Queue, Linked List, Queue, Deque, Stack, AVL Tree, Tree Multiset, Trie, Directed Graph, Undirected Graph, Singly Linked List, Doubly Linked List, Max Heap, Max Priority Queue, Min Heap, Min Priority Queue.",
5
5
  "main": "dist/index.js",
6
6
  "module": "lib/index.js",
7
7
  "types": "lib/index.d.ts",
8
8
  "source": "src/index.ts",
9
9
  "umd:main": "umd/bundle.min.js",
10
+ "exports": {
11
+ "import": "./lib/index.js",
12
+ "require": "./dist/index.js"
13
+ },
10
14
  "scripts": {
11
15
  "build": "npm run build:es6 && npm run build:commonjs && npm run build:umd && npm run build:docs",
12
16
  "build:es6": "rm -rf lib && tsc",
@@ -34,7 +38,7 @@
34
38
  "type": "git",
35
39
  "url": "git+https://github.com/zrwusa/data-structure-typed.git"
36
40
  },
37
- "author": "Tyler Zeng zrwusa@gmail.com",
41
+ "author": "Tyler Zeng <zrwusa@gmail.com>",
38
42
  "license": "MIT",
39
43
  "publishConfig": {
40
44
  "@zrwusa:registry": "https://npm.pkg.github.com"
@@ -50,17 +54,17 @@
50
54
  "@typescript-eslint/eslint-plugin": "^6.7.4",
51
55
  "@typescript-eslint/parser": "^6.7.4",
52
56
  "auto-changelog": "^2.4.0",
53
- "avl-tree-typed": "^1.35.0",
57
+ "avl-tree-typed": "^1.35.1",
54
58
  "benchmark": "^2.1.4",
55
- "binary-tree-typed": "^1.35.0",
56
- "bst-typed": "^1.35.0",
59
+ "binary-tree-typed": "^1.35.1",
60
+ "bst-typed": "^1.35.1",
57
61
  "dependency-cruiser": "^14.1.0",
58
62
  "eslint": "^8.50.0",
59
63
  "eslint-config-prettier": "^9.0.0",
60
64
  "eslint-import-resolver-alias": "^1.1.2",
61
65
  "eslint-import-resolver-typescript": "^3.6.1",
62
66
  "eslint-plugin-import": "^2.28.1",
63
- "heap-typed": "^1.35.0",
67
+ "heap-typed": "^1.35.1",
64
68
  "istanbul-badges-readme": "^1.8.5",
65
69
  "jest": "^29.7.0",
66
70
  "prettier": "^3.0.3",