com.zusmart.base.graph.DirectedGraph Maven / Gradle / Ivy
package com.zusmart.base.graph;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class DirectedGraph implements Iterable {
private final Map> nodes = new HashMap>();
public boolean addNode(T node) {
if (nodes.containsKey(node)) {
return false;
}
nodes.put(node, new HashSet());
return true;
}
public boolean addEdge(T head, T foot) {
if (!nodes.containsKey(head)) {
this.addNode(head);
}
if (!nodes.containsKey(foot)) {
this.addNode(foot);
}
nodes.get(head).add(foot);
return true;
}
public Set getEdges(T head) {
if (nodes.containsKey(head)) {
return Collections.unmodifiableSet(nodes.get(head));
} else {
return Collections.unmodifiableSet(new HashSet());
}
}
@Override
public Iterator iterator() {
return this.nodes.keySet().iterator();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy