С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 16, средняя оценка - 4.63
Healius
4 / 4 / 0
Регистрация: 06.05.2011
Сообщений: 50
#1

Алгоритм Флойда (теория графов) - C++

07.05.2011, 14:47. Просмотров 2349. Ответов 2
Метки нет (Все метки)

код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
int** floid(int** W,int n){
    vector<int**>D(n);
    int** A=new int*[n];
    for(int i=0;i<n;i++){
        A[i]=new int[n];
        for(int j=0;j<n;j++)
            A[i][j]=1;
    }
    for(int i=0;i<n;i++){
        for(int j=0;j<n;j++){
            if(i==j)
                A[i][j]=0;
            else{
                if(W[i][j]==0)
                    A[i][j]=100;
                else
                    A[i][j]=W[i][j];
            }
        }
    }
    D.push_back(A);
    int k=1;
    while(k<n){
        int** B=new int*[n];
        for(int i=0;i<n;i++){
            B[i]=new int[n];
            for(int j=0;j<n;j++)
                B[i][j]=1;
        }
        for(int i=0;i<n;i++){
            for(int j=0;j<n;j++){
                if(i!=j)
                    B[i][j]=min(D.back()[i][j],(D.back()[i][k]+D.back()[k][j]));
            }
        }
        k++;
        D.push_back(B);
    }
    return D.back();
}
на выходе должна быть матрица длин кратчайших путей, в пункции параметры - матрица весов графа и её размерность. проблема: алгоритм не видит пути через 0-ю вершину. подскажите плиз, в чем дело? остальные пути нормально вычисляет, алгоритм написан верно.

Добавлено через 16 часов 59 минут
народ, неужели никто не может помочь?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.05.2011, 14:47
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Алгоритм Флойда (теория графов) (C++):

Теория графов - C++
Есть задание. найти максимальное и среднее расстояние между центральными вершинами неориентированного графа. 1 Что такое центральные...

Теория графов. Задача Обрати меня! - C++
Мальчик Вася очень любит разворачивать ориентированные графы. Помогите ему в этом. Входные данные Во входном файле записано число N...

Алгоритм Флойда–Уоршелла - C++
for (int k=0; k&lt;n; k++) for (int i=0; i&lt;n; i++) for (int j=0; j&lt;n; j++) как сделать так, чтобы алгоритм нахождения кратчайшего...

Алгоритм Флойда Оршала - C++
Найти наикратчайшее расстояние от каждой до каждой. Задание представляет собой любую матрицу 4*4. Программа на языке C++.

Алгоритм Флойда - Уоршелла - C++
не получается реализовать алгоритм Флойда-Уоршелла, вроде все должнен выводить, а выводит или нули или вообще ничего, ошибок не выводит не...

Алгоритм Флойда С++ реализация - C++
Есть такой код класса Помогите, пожалуйста найти по методу Флойда самый короткий путь, он описан в void setstructGraf, но не могу...

2
Ultrator
11 / 7 / 1
Регистрация: 28.04.2009
Сообщений: 219
08.05.2011, 06:20 #2
Ну а, что в 22 строке, k=1 - так и должно быть?
0
Healius
4 / 4 / 0
Регистрация: 06.05.2011
Сообщений: 50
08.05.2011, 16:11  [ТС] #3
ну да, K обозначает шаг действия алгоритма, нулевой шаг уже сделан
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.05.2011, 16:11
Привет! Вот еще темы с ответами:

Алгоритм Флойда-Уоршела - C++
Ребят, помогите. На завтра нужно сдать алгоритм флойда. Вроде нашел код, но он не выводит САМО ЗНАЧЕНИЕ кратчайшего пути, а только по каким...

Алгоритм Флойда-Уоршалла граф - C++
Собственно мне дан ориентированный граф,в котором вес ребра между вершинами i и j допустим-это шанс добраться от вершины i к вершине j...

В чем ошибка? Алгоритм Флойда - C++
Не понимаю почему не запускается, может нужна еще кака-набудь библиотека? Программу нашел в интернете #include &lt;vcl.h&gt; #pragma...

Алгоритм Флойда-Уоршелла (результат работы неправильный) - C++
Задание выглядит так: Дан ориентированный взвешенный граф. Найти пару вершин, кратчайшее расстояние от одной из которых до другой...


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

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

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