Changed the source files for incorporating review comments on the tutorial.

This commit is contained in:
Kumar Chandrakant 2018-11-28 01:00:16 +05:30
parent 56ab8e2049
commit 7410f52561
2 changed files with 55 additions and 91 deletions

View File

@ -1,67 +1,57 @@
package com.baeldung.graph; package com.baeldung.graph;
import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.HashSet; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors; import java.util.stream.Collectors;
public class Graph { public class Graph {
private Set<Vertex> vertices; private Map<Vertex, List<Vertex>> adjVertices;
private Set<Edge> edges;
private Map<Vertex, Set<Edge>> adjVertices;
Graph() { Graph() {
this.vertices = new HashSet<Vertex>(); this.adjVertices = new HashMap<Vertex, List<Vertex>>();
this.edges = new HashSet<Edge>();
this.adjVertices = new HashMap<Vertex, Set<Edge>>();
} }
boolean addVertex(String label) { void addVertex(String label) {
return vertices.add(new Vertex(label)); adjVertices.putIfAbsent(new Vertex(label), new ArrayList<>());
} }
boolean removeVertex(String label) { void removeVertex(String label) {
return vertices.remove(new Vertex(label));
}
boolean addEdge(String label1, String label2) {
Vertex v1 = new Vertex(label1);
Vertex v2 = new Vertex(label2);
Edge e = new Edge(v1, v2);
if (this.edges.add(e)) {
adjVertices.putIfAbsent(v1, new HashSet<>());
adjVertices.putIfAbsent(v2, new HashSet<>());
adjVertices.get(v1)
.add(e);
adjVertices.get(v2)
.add(e);
}
return true;
}
boolean removeEdge(String label1, String label2) {
Vertex v1 = new Vertex(label1);
Vertex v2 = new Vertex(label2);
Edge e = new Edge(v1, v2);
if (this.edges.remove(e)) {
Set<Edge> eV1 = adjVertices.get(v1);
Set<Edge> eV2 = adjVertices.get(v2);
if (eV1 != null)
eV1.remove(e);
if (eV2 != null)
eV2.remove(e);
}
return true;
}
Set<Vertex> getAdjVertices(String label) {
Vertex v = new Vertex(label); Vertex v = new Vertex(label);
return adjVertices.get(v) adjVertices.values().stream().map(e -> e.remove(v)).collect(Collectors.toList());
.stream() adjVertices.remove(new Vertex(label));
.map(e -> e.v1.equals(v) ? e.v2 : e.v1) }
.collect(Collectors.toSet());
void addEdge(String label1, String label2) {
Vertex v1 = new Vertex(label1);
Vertex v2 = new Vertex(label2);
adjVertices.get(v1).add(v2);
adjVertices.get(v2).add(v1);
}
void removeEdge(String label1, String label2) {
Vertex v1 = new Vertex(label1);
Vertex v2 = new Vertex(label2);
List<Vertex> eV1 = adjVertices.get(v1);
List<Vertex> eV2 = adjVertices.get(v2);
if (eV1 != null)
eV1.remove(v2);
if (eV2 != null)
eV2.remove(v1);
}
List<Vertex> getAdjVertices(String label) {
return adjVertices.get(new Vertex(label));
}
String printGraph() {
StringBuffer sb = new StringBuffer();
for(Vertex v : adjVertices.keySet()) {
sb.append(v);
sb.append(adjVertices.get(v));
}
return sb.toString();
} }
class Vertex { class Vertex {
@ -83,30 +73,4 @@ public class Graph {
return label; return label;
} }
} }
class Edge {
Vertex v1;
Vertex v2;
Edge(String label1, String label2) {
this.v1 = new Vertex(label1);
this.v2 = new Vertex(label2);
}
Edge(Vertex vertex1, Vertex vertex2) {
this.v1 = vertex1;
this.v2 = vertex2;
}
@Override
public boolean equals(Object obj) {
Edge edge = (Edge) obj;
return edge.v1.equals(v1) && edge.v2.equals(v2);
}
@Override
public int hashCode() {
return v1.hashCode() + v2.hashCode();
}
@Override
public String toString() {
return v1.label + "-" + v2.label;
}
}
} }

View File

@ -7,30 +7,30 @@ public class GraphTraversalUnitTest {
@Test @Test
public void givenAGraph_whenTraversingDepthFirst_thenExpectedResult() { public void givenAGraph_whenTraversingDepthFirst_thenExpectedResult() {
Graph graph = createGraph(); Graph graph = createGraph();
Assert.assertEquals("[A, D, E, B, C]", Assert.assertEquals("[Bob, Rob, Maria, Alice, Mark]",
GraphTraversal.depthFirstTraversal(graph, "A").toString()); GraphTraversal.depthFirstTraversal(graph, "Bob").toString());
} }
@Test @Test
public void givenAGraph_whenTraversingBreadthFirst_thenExpectedResult() { public void givenAGraph_whenTraversingBreadthFirst_thenExpectedResult() {
Graph graph = createGraph(); Graph graph = createGraph();
Assert.assertEquals("[A, B, D, C, E]", Assert.assertEquals("[Bob, Alice, Rob, Mark, Maria]",
GraphTraversal.breadthFirstTraversal(graph, "A").toString()); GraphTraversal.breadthFirstTraversal(graph, "Bob").toString());
} }
Graph createGraph() { Graph createGraph() {
Graph graph = new Graph(); Graph graph = new Graph();
graph.addVertex("A"); graph.addVertex("Bob");
graph.addVertex("B"); graph.addVertex("Alice");
graph.addVertex("C"); graph.addVertex("Mark");
graph.addVertex("D"); graph.addVertex("Rob");
graph.addVertex("E"); graph.addVertex("Maria");
graph.addEdge("A", "B"); graph.addEdge("Bob", "Alice");
graph.addEdge("A", "D"); graph.addEdge("Bob", "Rob");
graph.addEdge("B", "C"); graph.addEdge("Alice", "Mark");
graph.addEdge("D", "C"); graph.addEdge("Rob", "Mark");
graph.addEdge("B", "E"); graph.addEdge("Alice", "Maria");
graph.addEdge("D", "E"); graph.addEdge("Rob", "Maria");
return graph; return graph;
} }
} }