Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
Sveta_07
0 / 0 / 0
Регистрация: 07.09.2014
Сообщений: 1
#1

Реализация АТД Взвешенный орграф. Не корректно считает радиус и путь

10.09.2014, 13:11. Просмотров 633. Ответов 1
Метки нет (Все метки)

Помогите пожалуйста найти ошибку в решении задачи:

Реализация АТД «Взвешенный орграф». Граф представлен в виде списков смежности. Определение радиуса и соответствующего радиусу пути взвешенного орграфа на основе алгоритма Дейкстры. (радиус – минимальный эксцентриситет в графе, путь- последовательность вершин, лежащих на пути с суммарным весом ребер, равным радиусу).

Не корректно считает радиус и путь
 Комментарий модератора 
Тексты нужно перепечатывать в сообщение!

 Комментарий модератора 
Примечание: в архиве проект для VisualStudio.
0
Вложения
Тип файла: rar KR2.rar (5.83 Мб, 32 просмотров)
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.09.2014, 13:11
Ответы с готовыми решениями:

Написать программу, которая предлагает пользователю ввести радиус окружности и считает площадь этой окружнос
Написать программу, которая предлагает пользователю ввести радиус окружности ...

Орграф, элементарный путь
Необходимо найти элементарный путь длинны l на орграфе. Не пойму как это можно...

Представление и реализация атд «список
помогите,пожалуйста...заранее спасибо)) 1)Составить оператор PRINT_i,...

Реализация АТД стек на базе связного списка
Здравствуйте, очень прошу вашей помощи. Необходимо реализовать стек на базе...

Запрос не корректно считает
Бьюсь с запросом вычисляющим остатки. Разницей полей в таблицах...

1
skMaster
4 / 4 / 5
Регистрация: 26.02.2013
Сообщений: 39
Завершенные тесты: 1
29.06.2015, 23:13 #2
Лучший ответ Сообщение было отмечено как решение

Решение

В файле Graph.h правим:
C++
1
2
3
4
5
6
...template <class Data, class Weight>
void Graph<Data, Weight>::Dijkstra(
    Node<Data, Weight> *from,
    std::vector<Weight> &dist, // вектор эксцентриситетов
    std::vector<Node<Data, Weight>*> path // путь
)...
Меняем на:
C++
1
2
3
4
5
6
...template <class Data, class Weight>
void Graph<Data, Weight>::Dijkstra(
    Node<Data, Weight> *from,
    std::vector<Weight> &dist, // вектор эксцентриситетов
    std::vector<Node<Data, Weight>*> &path // путь
)...
(меняем в описании класса и при объявлении метода)
Затем:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
template <class Data, class Weight>
Weight Graph<Data, Weight>::exstrisitet(Node<Data, Weight> *from) {
    std::vector<Weight> dist;
    std::vector<Node<Data, Weight>*> path;
    Dijkstra(from, dist, path);
    Weight maxWeight = dist[0];
    for (int i = 1; i < dist.size();i++)
    {
        if (dist[i] == LONG_MAX) continue;
        if (maxWeight < dist[i]) {
            maxWeight = dist[i];
        }
    }
    return maxWeight;
}
Меняем на:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
template <class Data, class Weight>
Weight Graph<Data, Weight>::exstrisitet(Node<Data, Weight> *from) {
    std::vector<Weight> dist;
    std::vector<Node<Data, Weight>*> path;
    Dijkstra(from, dist, path);
    Weight maxWeight = dist[0];
    if (maxWeight > 100) maxWeight = -1;
    for (int i = 1; i < dist.size();i++)
    {
        if (dist[i] > 100) continue;
        if (maxWeight < dist[i]) {
            maxWeight = dist[i];
        }
    }
    return maxWeight;
}
LONG_MAX я конечно понимаю откуда берется, но лучше сделать сравнение с чемнить поменьше (с любым числом, которое не будут превышать веса рёбер). Проверяем функции 7 и 8 и видим радиус и путь, сгенеренные по алгоритму Дейкстра.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.06.2015, 23:13

Формула не считает корректно
Пытаюсь решить задание, но формула не считает корректно Исходные данные: P...

Delphi. Не корректно считает матрицы
Пример считает не верно, пишет матрица заполнена не полностью. var i, j,...

Некоторые Ответы Выводятся Как Nan, Хотя Считает Корректно, Вроде
Всем привет В коде в некоторых ответах (значение х равный дробному...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru