shortest path

This commit is contained in:
Raphael Rees 2023-03-29 15:56:11 +02:00
parent 96dc076c30
commit 8ca8f98b7e

View file

@ -51,14 +51,23 @@ public class Path {
* @throws IllegalArgumentException If the list of nodes is not valid, i.e. two
* consecutive nodes in the list are not connected in the graph.
*
* @deprecated Need to be implemented.
*/
public static Path createShortestPathFromNodes(Graph graph, List<Node> nodes)
throws IllegalArgumentException {
List<Arc> arcs = new ArrayList<Arc>();
Arc candidat = null;
Node deb = nodes.remove(0);
for(Node fin : nodes){
List<Node> nodes2 = nodes;
Arc candidat = null; //arc candidat à être le plus court entre deux nodes
if(nodes.size()==0){
return new Path(graph);
}
else if(nodes.size()==1){
return new Path(graph,nodes.get(0));
}
else{
Node deb = nodes2.get(0);
for(Node fin : nodes2){
if(!fin.equals(deb)){
float dist = Float.MAX_VALUE;
for(Arc a : deb.getSuccessors()){
if(a.getDestination().equals(fin)&&dist>a.getLength()){
@ -66,12 +75,15 @@ public class Path {
candidat=a;
}
}
if(dist==Float.MAX_VALUE){
throw new IllegalArgumentException("Liste de noeuds non valide");
}
arcs.add(candidat);
deb = fin;
}
}
}
return new Path(graph, arcs);
}