У меня есть матрица смежности adj, которая определена ниже:
0 0 0 1 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 1 0 0 0
1 0 0 0 1 0 1 0 0
0 0 0 1 0 1 0 0 0
0 0 1 0 1 0 0 0 1
0 0 0 1 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 1 0 0 0
Я ломаю голову над разработкой алгоритма BFS для обхода графа с учетом начальной и конечной позиции.
Моя лучшая попытка дает серию ходов, но не самую короткую.
boolean[] pass = new boolean[9]; //if a move has been done, don't redo it
int s = 0; //starting position
int e = 2; //ending position
int[][] matrix; //the adjacency matrix previous defined
public List<Integer> BFS(int[][] matrix, int s) {
List<Integer> paths = new LinkedList();
List<Integer> shortest = new LinkedList();
pass[s] = true; //starting position has been indexed
paths.add(0,s); //insert part of path to front of list
while (paths.isEmpty() == false) {
int element = paths.get(0); //peek at first element
shortest.add(element); //add it to shortest path
int node = paths.remove(0); //remove from path
if (element == e) { //if we've reached the end
return shortest; //hopefully found shortest path
} else {
for (int i = 0; i < 9; i++) {
//if adjacent element hasn't been indexed
if (pass[i] == false && matrix[node][i] == 1) {
pass[i] = true;
paths.add(0,i);
}
}
}
}
return null;
}
Печать возвращенного списка дает:
[0, 3, 6, 4, 5, 8, 2]
Когда фактический результат должен быть:
[0, 3, 4, 5, 2]
Мне кажется, что путь, по которому он идет, выглядит примерно так:
[0, 3, 6, backtrack to 3, 4, 5, 8, backtrack to 5, 2]
Что не так с моим алгоритмом? Как найти кратчайший путь, зная начальную и конечную точки?
Вот пример IDEone для иллюстрации.