157 lines
6.4 KiB
Java
157 lines
6.4 KiB
Java
|
/*This is a Java Program to perform Dijkstra’s Shortest path algorithm. For a given source vertex (node) in the graph, the algorithm finds the path with lowest cost (i.e. the shortest path) between that vertex and every other vertex. It can also be used for finding costs of shortest paths from a single vertex to a single destination vertex by stopping the algorithm once the shortest path to the destination vertex has been determined. For example, if the vertices of the graph represent cities and edge path costs represent driving distances between pairs of cities connected by a direct road, Dijkstra’s algorithm can be used to find the shortest route between one city and all other cities.*/
|
|||
|
|
|||
|
//This is a java program to find the shortest path between source vertex and destination vertex
|
|||
|
import java.util.HashSet;
|
|||
|
import java.util.InputMismatchException;
|
|||
|
import java.util.Iterator;
|
|||
|
import java.util.Scanner;
|
|||
|
import java.util.Set;
|
|||
|
|
|||
|
public class Dijkstras_Shortest_Path
|
|||
|
{
|
|||
|
private int distances[];
|
|||
|
private Set<Integer> settled;
|
|||
|
private Set<Integer> unsettled;
|
|||
|
private int number_of_nodes;
|
|||
|
private int adjacencyMatrix[][];
|
|||
|
|
|||
|
public Dijkstras_Shortest_Path(int number_of_nodes)
|
|||
|
{
|
|||
|
this.number_of_nodes = number_of_nodes;
|
|||
|
distances = new int[number_of_nodes + 1];
|
|||
|
settled = new HashSet<Integer>();
|
|||
|
unsettled = new HashSet<Integer>();
|
|||
|
adjacencyMatrix = new int[number_of_nodes + 1][number_of_nodes + 1];
|
|||
|
}
|
|||
|
|
|||
|
public void dijkstra_algorithm(int adjacency_matrix[][], int source)
|
|||
|
{
|
|||
|
int evaluationNode;
|
|||
|
for (int i = 1; i <= number_of_nodes; i++)
|
|||
|
for (int j = 1; j <= number_of_nodes; j++)
|
|||
|
adjacencyMatrix[i][j] = adjacency_matrix[i][j];
|
|||
|
for (int i = 1; i <= number_of_nodes; i++)
|
|||
|
{
|
|||
|
distances[i] = Integer.MAX_VALUE;
|
|||
|
}
|
|||
|
unsettled.add(source);
|
|||
|
distances[source] = 0;
|
|||
|
while (!unsettled.isEmpty())
|
|||
|
{
|
|||
|
evaluationNode = getNodeWithMinimumDistanceFromUnsettled();
|
|||
|
unsettled.remove(evaluationNode);
|
|||
|
settled.add(evaluationNode);
|
|||
|
evaluateNeighbours(evaluationNode);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
private int getNodeWithMinimumDistanceFromUnsettled()
|
|||
|
{
|
|||
|
int min;
|
|||
|
int node = 0;
|
|||
|
Iterator<Integer> iterator = unsettled.iterator();
|
|||
|
node = iterator.next();
|
|||
|
min = distances[node];
|
|||
|
for (int i = 1; i <= distances.length; i++)
|
|||
|
{
|
|||
|
if (unsettled.contains(i))
|
|||
|
{
|
|||
|
if (distances[i] <= min)
|
|||
|
{
|
|||
|
min = distances[i];
|
|||
|
node = i;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
return node;
|
|||
|
}
|
|||
|
|
|||
|
private void evaluateNeighbours(int evaluationNode)
|
|||
|
{
|
|||
|
int edgeDistance = -1;
|
|||
|
int newDistance = -1;
|
|||
|
for (int destinationNode = 1; destinationNode <= number_of_nodes; destinationNode++)
|
|||
|
{
|
|||
|
if (!settled.contains(destinationNode))
|
|||
|
{
|
|||
|
if (adjacencyMatrix[evaluationNode][destinationNode] != Integer.MAX_VALUE)
|
|||
|
{
|
|||
|
edgeDistance = adjacencyMatrix[evaluationNode][destinationNode];
|
|||
|
newDistance = distances[evaluationNode] + edgeDistance;
|
|||
|
if (newDistance < distances[destinationNode])
|
|||
|
{
|
|||
|
distances[destinationNode] = newDistance;
|
|||
|
}
|
|||
|
unsettled.add(destinationNode);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
public static void main(String... arg)
|
|||
|
{
|
|||
|
int adjacency_matrix[][];
|
|||
|
int number_of_vertices;
|
|||
|
int source = 0, destination = 0;
|
|||
|
Scanner scan = new Scanner(System.in);
|
|||
|
try
|
|||
|
{
|
|||
|
System.out.println("Enter the number of vertices");
|
|||
|
number_of_vertices = scan.nextInt();
|
|||
|
adjacency_matrix = new int[number_of_vertices + 1][number_of_vertices + 1];
|
|||
|
System.out.println("Enter the Weighted Matrix for the graph");
|
|||
|
for (int i = 1; i <= number_of_vertices; i++)
|
|||
|
{
|
|||
|
for (int j = 1; j <= number_of_vertices; j++)
|
|||
|
{
|
|||
|
adjacency_matrix[i][j] = scan.nextInt();
|
|||
|
if (i == j)
|
|||
|
{
|
|||
|
adjacency_matrix[i][j] = 0;
|
|||
|
continue;
|
|||
|
}
|
|||
|
if (adjacency_matrix[i][j] == 0)
|
|||
|
{
|
|||
|
adjacency_matrix[i][j] = Integer.MAX_VALUE;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
System.out.println("Enter the source ");
|
|||
|
source = scan.nextInt();
|
|||
|
System.out.println("Enter the destination ");
|
|||
|
destination = scan.nextInt();
|
|||
|
Dijkstras_Shortest_Path dijkstrasAlgorithm = new Dijkstras_Shortest_Path(
|
|||
|
number_of_vertices);
|
|||
|
dijkstrasAlgorithm.dijkstra_algorithm(adjacency_matrix, source);
|
|||
|
System.out.println("The Shorted Path from " + source + " to " + destination + " is: ");
|
|||
|
for (int i = 1; i <= dijkstrasAlgorithm.distances.length - 1; i++)
|
|||
|
{
|
|||
|
if (i == destination)
|
|||
|
System.out.println(source + " to " + i + " is "
|
|||
|
+ dijkstrasAlgorithm.distances[i]);
|
|||
|
}
|
|||
|
}
|
|||
|
catch (InputMismatchException inputMismatch)
|
|||
|
{
|
|||
|
System.out.println("Wrong Input Format");
|
|||
|
}
|
|||
|
scan.close();
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
|
|||
|
Enter the number of vertices
|
|||
|
5
|
|||
|
Enter the Weighted Matrix for the graph
|
|||
|
0 9 6 5 3
|
|||
|
0 0 0 0 0
|
|||
|
0 2 0 4 0
|
|||
|
0 0 0 0 0
|
|||
|
0 0 0 0 0
|
|||
|
Enter the source
|
|||
|
1
|
|||
|
Enter the destination
|
|||
|
4
|
|||
|
The Shorted Path from 1 to 4 is:
|
|||
|
1 to 4 is 5
|