|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|||||||||||
Вывод пути (алгоритм Дейкстры)04.06.2014, 01:58. Показов 20782. Ответов 31
Метки нет (Все метки)
Реализация алгоритма Дейкстра.
В массиве distance - найденные кратчайшие пути, visited - логический, для хранения информации о посещенных вершинах. Вместо "нубского" вывода пройденного пути из первой вершины в последнюю, необходимо реализовать нормальный вывод точек, через которые был проложен путь.
Кликните здесь для просмотра всего текста
0
|
|||||||||||
| 04.06.2014, 01:58 | |
|
Ответы с готовыми решениями:
31
Алгоритм Дейкстры, нахождение кратчайшего пути
Нужен алгоритм поиска пути в этом лабиринте (будь то волновой алгоритм или алгоритм правой/левой руки ) |
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
| 04.06.2014, 02:36 | |
|
http://e-maxx.ru/algo/dijkstra , прочитай пункт восстановление пути
0
|
|
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|
| 04.06.2014, 03:03 [ТС] | |
|
iliya785, читал, читаю - ничего не выходит
0
|
|
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
| 04.06.2014, 22:22 | |
|
если всё так плохо , то могу допилить , а также подебажить код. Также могу объяснить восстановление пути или сам алгоритм.
0
|
|
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|
| 04.06.2014, 22:35 [ТС] | |
|
да сам алгоритм и код я понимаю, мне нужны идеи насчёт того, как построить путь
0
|
|
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
| 04.06.2014, 23:03 | |
Сообщение было отмечено 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 [ТС] | |||||||
|
iliya785,
0
|
|||||||
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
||||||
| 04.06.2014, 23:25 | ||||||
0
|
||||||
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
||||||
| 04.06.2014, 23:39 [ТС] | ||||||
0
|
||||||
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|
| 04.06.2014, 23:46 [ТС] | |
|
и так по циклу с моей первой точки, до последней, выводится длина пути
0
|
|
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
| 04.06.2014, 23:49 | |
|
скинь весь код
0
|
|
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
||||||
| 04.06.2014, 23:52 [ТС] | ||||||
|
Кликните здесь для просмотра всего текста
0
|
||||||
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
||||||
| 05.06.2014, 00:37 | ||||||
|
Написпл весь код снуля (были серьёзные баги) statrt , finish можешь изменить из main
напиши , что нужно добавить , я тогда сделаю , а то чувствую затянится это надолго
1
|
||||||
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|
| 05.06.2014, 00:40 [ТС] | |
|
ну и ну
теперь бы понять что это вообще всё такое, для чего нужны вектора (не знаком с ними)))) и ещё когда меняю значения старт и финиш, оно зацикливается и завершается также нужно вывести вес пути он должен быть 60
0
|
|
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
| 05.06.2014, 00:42 | |
|
напиши на каких данных циклится
0
|
|
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
||||||
| 05.06.2014, 00:45 [ТС] | ||||||
|
мне же нужен путь из 1 точки в 10, поэтому:
0
|
||||||
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
|
| 05.06.2014, 00:53 | |
|
матрица 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 [ТС] | ||||||
|
понял
0-2-6-7-9 а должен быть 0-1-5-6-7-9
0
|
||||||
|
24 / 24 / 12
Регистрация: 04.06.2014
Сообщений: 80
|
||||||
| 05.06.2014, 00:59 | ||||||
|
нашёл баг , теперь всё ок
0 - это отсутствие ребра , или налчие ребра нулевой стоимости ?
1
|
||||||
|
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
|
|
| 05.06.2014, 01:03 [ТС] | |
|
то есть по этому пути вес получится 65, а минимальный - 60
Добавлено через 2 минуты 0 - отсутствие ребра Добавлено через 2 минуты теперь выводит другой путь - 0-1-3-4-7-9, но вес всё равно 65, а не нужный 60
0
|
|
| 05.06.2014, 01:03 | |
|
Помогаю со студенческими работами здесь
20
Алгоритм Дейкстры Алгоритм Дейкстры Алгоритм Дейкстры Алгоритм Дейкстры Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|