Libraryless. Click here for Pure Java version (5329L/30K).
1 | sclass BreadthFirstPathFinder<A> implements Steppable {
|
2 | // must set |
3 | IF1<A, Cl<A>> getChildren; |
4 | |
5 | // graph representation - filled during exploration |
6 | new MultiMap<A> links; |
7 | |
8 | // node queue (temporary) |
9 | new LinkedList<A> queue; |
10 | |
11 | *() {}
|
12 | *(IF1<A, Cl<A>> *getChildren) {}
|
13 | *(IF1<A, Cl<A>> *getChildren, A startNode) { add(startNode); }
|
14 | |
15 | void add(A a, A prev default null) {
|
16 | if (!links.containsKey(a)) {
|
17 | links.put(a, prev); |
18 | queue.add(a); |
19 | } |
20 | } |
21 | |
22 | public bool step() {
|
23 | ping(); |
24 | if (empty(queue)) false; |
25 | A a = popFirst(queue); |
26 | fOr (A b : getChildren.get(a)) |
27 | add(b, a); |
28 | true; |
29 | } |
30 | |
31 | bool nodeReached(A a) {
|
32 | ret links.containsKey(a); |
33 | } |
34 | |
35 | Cl<A> getBackLinks(A a) {
|
36 | ret links.get(a); |
37 | } |
38 | |
39 | L<A> examplePath(A start, A dest) {
|
40 | new L<A> path; |
41 | A node = dest; |
42 | path.add(node); |
43 | do {
|
44 | if (node == null) null; // no path found |
45 | node = first(getBackLinks(node)); |
46 | path.add(node); |
47 | } while (node != start); |
48 | ret reversed(path); |
49 | } |
50 | } |
Began life as a copy of #1021566
download show line numbers debug dex old transpilations
Travelled to 4 computer(s): bhatertpkbcr, mqqgnosmbjvj, pyentgdyhuwx, vouqrxazstgt
No comments. add comment
| Snippet ID: | #1030913 |
| Snippet name: | BreadthFirstPathFinder - breadth-first search along virtual structure, collecting links [OK] |
| Eternal ID of this version: | #1030913/15 |
| Text MD5: | 31151c97a27f9ce254ca61184aac2a04 |
| Transpilation MD5: | 8eb4c2f55213f214e172820f0d3b7c71 |
| Author: | stefan |
| Category: | javax |
| Type: | JavaX fragment (include) |
| Public (visible to everyone): | Yes |
| Archived (hidden from active list): | No |
| Created/modified: | 2022-03-21 23:29:32 |
| Source code size: | 1086 bytes / 50 lines |
| Pitched / IR pitched: | No / No |
| Views / Downloads: | 457 / 763 |
| Version history: | 14 change(s) |
| Referenced in: | [show references] |