programming-examples/java/Data_Structures/Graph.java
2019-11-15 12:59:38 +01:00

46 lines
850 B
Java

import java.util.*;
public class Graph {
public Map<Integer, Set<Integer>> edges = new TreeMap<>();
public void addNode(int u) {
if (!edges.containsKey(u)) {
edges.put(u, new TreeSet<Integer>());
}
}
public void removeNode(int u) {
if (!edges.containsKey(u)) {
return;
}
for (int v : edges.get(u)) {
edges.get(v).remove(u);
}
edges.remove(u);
}
public void addEdge(int u, int v) {
addNode(u);
addNode(v);
edges.get(u).add(v);
edges.get(v).add(u);
}
public void removeEdge(int u, int v) {
edges.get(u).remove(v);
edges.get(v).remove(u);
}
// Usage example
public static void main(String[] args) {
Graph g = new Graph();
g.addEdge(0, 1);
g.addEdge(1, 2);
System.out.println(g.edges);
g.removeEdge(1, 0);
System.out.println(g.edges);
g.removeNode(1);
System.out.println(g.edges);
}
}