com.kenshoo.pl.entity.internal.fetch.BFS Maven / Gradle / Ivy
package com.kenshoo.pl.entity.internal.fetch;
import com.google.common.collect.TreeTraverser;
import org.jooq.lambda.Seq;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.function.Function;
import static java.util.Collections.singletonList;
import static org.jooq.lambda.Seq.seq;
import static org.jooq.lambda.function.Functions.not;
public class BFS {
public static Seq visit(Tree root, Function> neighbours) {
TreeTraverser visitor = new TreeTraverser() {
Set alreadyVisited = new HashSet<>(singletonList(root));
@Override
public Iterable children(Tree node) {
List unvisitedChildren = seq(neighbours.apply(node)).filter(not(alreadyVisited::contains)).toList();
alreadyVisited.addAll(unvisitedChildren);
return unvisitedChildren;
}
};
return seq(visitor.breadthFirstTraversal(root));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy