Skip to content

Commit

Permalink
#204 fix: BFS implementation
Browse files Browse the repository at this point in the history
  • Loading branch information
trungnotchung committed Oct 28, 2024
1 parent 742ea7f commit 09092f3
Show file tree
Hide file tree
Showing 2 changed files with 1,998 additions and 2,495 deletions.
50 changes: 23 additions & 27 deletions packages/object/src/hashgraph/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -223,45 +223,41 @@ export class HashGraph {
return test1 || test2;
}

// Time complexity: O(V), Space complexity: O(V)
areCausallyRelatedUsingBFS(hash1: Hash, hash2: Hash): boolean {
private _areCausallyRelatedUsingBFS(start: Hash, target: Hash): boolean {
const visited = new Set<Hash>();
const stack = [hash1];

while (stack.length > 0) {
const current = stack.pop();
if (current === hash2) return true;
const queue: Hash[] = [];
let head = 0;

queue.push(start);

while (head < queue.length) {
const current = queue[head];
head++;

if (current === target) return true;
if (current === undefined) continue;

visited.add(current);

const vertex = this.vertices.get(current);
if (!vertex) continue;

for (const dep of vertex.dependencies) {
if (!visited.has(dep)) {
stack.push(dep);
queue.push(dep);
}
}
}

visited.clear();
stack.push(hash2);

while (stack.length > 0) {
const current = stack.pop();
if (current === hash1) return true;
if (current === undefined) continue;
visited.add(current);

const vertex = this.vertices.get(current);
if (!vertex) continue;
for (const dep of vertex.dependencies) {
if (!visited.has(dep)) {
stack.push(dep);
}

if (head > queue.length / 2) {
queue.splice(0, head);
head = 0;
}
}

return false;
}

// Time complexity: O(V), Space complexity: O(V)
areCausallyRelatedUsingBFS(hash1: Hash, hash2: Hash): boolean {
return this._areCausallyRelatedUsingBFS(hash1, hash2) || this._areCausallyRelatedUsingBFS(hash2, hash1);
}

// Time complexity: O(1), Space complexity: O(1)
Expand Down
Loading

0 comments on commit 09092f3

Please sign in to comment.