6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|||||||||||
1 | |||||||||||
Вывод пути (алгоритм Дейкстры)04.06.2014, 01:58. Показов 20252. Ответов 31
Метки нет (Все метки)
Реализация алгоритма Дейкстра.
В массиве distance - найденные кратчайшие пути, visited - логический, для хранения информации о посещенных вершинах. Вместо "нубского" вывода пройденного пути из первой вершины в последнюю, необходимо реализовать нормальный вывод точек, через которые был проложен путь.
Кликните здесь для просмотра всего текста
0
|
04.06.2014, 01:58 | |
Ответы с готовыми решениями:
31
Алгоритм Дейкстры, нахождение кратчайшего пути Определение кратчайшего пути алгоритмом Дейкстры Нужен алгоритм поиска пути в этом лабиринте (будь то волновой алгоритм или алгоритм правой/левой руки ) Определение радиуса и соответствующего радиусу пути взвешенного орграфа на основе алгоритма Дейкстры |
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
04.06.2014, 02:36 | 2 |
http://e-maxx.ru/algo/dijkstra , прочитай пункт восстановление пути
0
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|
04.06.2014, 03:03 [ТС] | 3 |
iliya785, читал, читаю - ничего не выходит
0
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
04.06.2014, 22:22 | 4 |
если всё так плохо , то могу допилить , а также подебажить код. Также могу объяснить восстановление пути или сам алгоритм.
0
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|
04.06.2014, 22:35 [ТС] | 5 |
да сам алгоритм и код я понимаю, мне нужны идеи насчёт того, как построить путь
0
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
04.06.2014, 23:03 | 6 |
Сообщение было отмечено Aecttann как решение
Решение
заведём массив p, где p[i] - вершина из которой мы пришли в вершину i(предок i), изменять значения этого массива будем там же где и улучшаем массив расстояний(у тебя это массив distance, в теле if'a, который на строке 40 нужно дописать p[i] = u). Теперь как восстанавливаем путь: пусть мы находимся в вершине finish(путь из start->finish) теперь перейдём в предка вершины finish(это p[finish]), далее перейдём в предка вершины p[finish](p[p[finish]]) и продолжаем пока не прийдем к старт(если надо могу эту часть кода написать). Остаётся только перевернуть путь (т.к. мы двигались из finish->start). Если есть ещё вопросы пиши, постараюсь ответить
0
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
||||||
04.06.2014, 23:23 [ТС] | 7 | |||||
iliya785,
не понимаю, что и как сделать в этом цикле)
0
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
||||||
04.06.2014, 23:25 | 8 | |||||
0
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
||||||
04.06.2014, 23:39 [ТС] | 9 | |||||
0
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|
04.06.2014, 23:46 [ТС] | 10 |
и так по циклу с моей первой точки, до последней, выводится длина пути
0
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
04.06.2014, 23:49 | 11 |
скинь весь код
0
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
||||||
04.06.2014, 23:52 [ТС] | 12 | |||||
Кликните здесь для просмотра всего текста
0
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
||||||
05.06.2014, 00:37 | 13 | |||||
Написпл весь код снуля (были серьёзные баги) statrt , finish можешь изменить из main
напиши , что нужно добавить , я тогда сделаю , а то чувствую затянится это надолго
1
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|
05.06.2014, 00:40 [ТС] | 14 |
ну и ну
теперь бы понять что это вообще всё такое, для чего нужны вектора (не знаком с ними)))) и ещё когда меняю значения старт и финиш, оно зацикливается и завершается также нужно вывести вес пути он должен быть 60
0
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
05.06.2014, 00:42 | 15 |
напиши на каких данных циклится
0
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
||||||
05.06.2014, 00:45 [ТС] | 16 | |||||
мне же нужен путь из 1 точки в 10, поэтому:
0
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
05.06.2014, 00:53 | 17 |
матрица g[n][n], где n = 10, это значит что можно работать со столбцами и строками размера <= 9 (нумерация с 0). Происходит выход за пределы массива.
Добавлено через 5 минут а vector в C++ , штука полезная. Вообще это динамический массив. объявляется он так vector < type (например int) > название. у него есть несколько конструкторов например: vector <type> name(size,val) - выделяем массив name на size элеметов и заполняем его val vector <type> name(size) - выделяем массив name на size элеметов и заполняем дефолтными значениями vector <type> name - это динамический массив, добавление с помощью метода push_back
1
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
||||||
05.06.2014, 00:56 [ТС] | 18 | |||||
понял
0-2-6-7-9 а должен быть 0-1-5-6-7-9
0
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
||||||
05.06.2014, 00:59 | 19 | |||||
нашёл баг , теперь всё ок
0 - это отсутствие ребра , или налчие ребра нулевой стоимости ?
1
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|
05.06.2014, 01:03 [ТС] | 20 |
то есть по этому пути вес получится 65, а минимальный - 60
Добавлено через 2 минуты 0 - отсутствие ребра Добавлено через 2 минуты теперь выводит другой путь - 0-1-3-4-7-9, но вес всё равно 65, а не нужный 60
0
|
05.06.2014, 01:03 | |
05.06.2014, 01:03 | |
Помогаю со студенческими работами здесь
20
Алгоритм Дейкстры Алгоритм Дейкстры Алгоритм Дейкстры Алгоритм Дейкстры Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |