Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на C / C++


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный ХОСТИНГ на базе Linux x64 и Windows x64

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Лучшие эксперты данной рассылки

Асмик Александровна
Статус: Академик
Рейтинг: 8121
∙ повысить рейтинг »
Boriss
Статус: Академик
Рейтинг: 2670
∙ повысить рейтинг »
Абаянцев Юрий Леонидович aka Ayl
Статус: Профессионал
Рейтинг: 2260
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И СОФТ / Программирование / C/C++

Номер выпуска:1670
Дата выхода:27.05.2011, 13:00
Администратор рассылки:Киселёва Алёна aka Verena (Профессор)
Подписчиков / экспертов:307 / 180
Вопросов / ответов:1 / 1

Вопрос № 183281: Здравствуйте! Прошу помощи в следующем вопросе: Мне надо написать программу на C++ . Задан орграф. Известны веса рёбер. Найти путь из i в j с min суммой весов рёбер. (Граф (веса) и число вершин вводить с экрана. Если можно, не исп...



Вопрос № 183281:

Здравствуйте! Прошу помощи в следующем вопросе:
Мне надо написать программу на C++ .

Задан орграф. Известны веса рёбер. Найти путь из i в j с min суммой весов рёбер.

(Граф (веса) и число вершин вводить с экрана.
Если можно, не использовать векторы.)

Отправлен: 22.05.2011, 12:44
Вопрос задал: sveta11115 (Посетитель)
Всего ответов: 1
Страница вопроса »


Отвечает Киселёва Алёна aka Verena (Профессор) :
Здравствуйте, sveta11115!
Для решения данной задачи можно использовать алгоритм Дейкстры. Данный алгоритм накладывает, правда, некоторые ограничения, в частности, веса рёбер не могут быть отрицательными.
В данном случае мы будем рекурсивно искать кратчайшие пути от вершины i до всех вершин графа, метка, которую мы поставим на вершине j и будет являться длиной кратчайшего по сумме весов пути. Если необходимо получить данные о том, по каким рёбрам этот путь прошёл, надо будет хранить дополнительную информацию, при имеющейся реализации узнать это нельзя.
При проверке учитывайте, что нумерация вершин идёт с нуля, то есть если вершины в графе три, то они будут иметь номера 0, 1, 2, а обращение к вершине 3 вызовет ошибку, потому что её не существует.
Реализация основана на этом коде, только убрала векторы, добавила проверку на ориентацию ребра при его проходе и исправила небольшую ошибку (искался не минимальный путь).
Проверено на Visual Studio 2005.

Удачи!

Приложение:

-----
Эта история - не для истории, понимаешь?

Ответ отправил: Киселёва Алёна aka Verena (Профессор)
Ответ отправлен: 26.05.2011, 15:31
Номер ответа: 267397
Россия, Москва
Адрес: Москва, Солнцево
Адрес сайта: Портал Вникуда: творчество, цитаты, события.
ICQ # 230360822

Оценка ответа: 5

Вам помог ответ? Пожалуйста, поблагодарите эксперта за это!
Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 267397 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:


  • Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.



    В избранное