Форум программистов, компьютерный форум CyberForum.ru

Поиск кратчайшего пути в графе - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ if..else http://www.cyberforum.ru/cpp-beginners/thread410189.html
уважаемые программисты, столкнулась с таким моментом в коде int kk; for(kk=0; kk<2; kk++) { if(kk) { //что-то }
C++ Найти значение выражения Как написать программу, чтобы вычислить значение выражения рекурентно: S= sum(A^i *(2i+1) + sumb^(k+1) Добавлено через 1 час 41 минуту :cry: Добавлено через 8 часов 26 минут Помогите тогда просто возвести число в степень, pow не работает ! http://www.cyberforum.ru/cpp-beginners/thread410181.html
C++ Программная реализация криптоалгоритма с абсолютной криптостойкостью «Одноразовый блокнот»
Друзья, товарищи! Прошу вашей помощи в реализации задания. Прошу помочь кто чем может. 1. Программа шифрования должна считывать ключевую последовательность из файла K.txt, открытый текст из файла М.txt и записывать шифр в файл C.txt 2. Программа дешифрования должна считывать ключевую последовательность из файла K.txt, шифр из файла C.txt и записывать открытый текст в файл М1.txt Генерация...
задачи с функиями C++
С помощью координат заданы 4 точки в трехмерном пространстве. Определить пару точек наиболее близких друг к другу.
C++ C++ Visual Studio http://www.cyberforum.ru/cpp-beginners/thread410129.html
Здравствуйте. Появилась проблемма с решением курсовой работы в некоторых вопросах. Буду безмерно благодарен за помощь. Задание 1. Что содержат файлы *. h в проекте C + + Visual Studio? Задание 2 Какие значения получат переменные A, B, C, D, E, F при выполнении программы int N = 15 ; int A,B,C,D,E,F;
C++ В матрице поменять местами строку В матрице поменять местами строку, содержащую элемент с наибольшим значением, со строкой, содержащей элемент с наименьшим значением. Предполагается, что эти элементы единственны. подробнее

Показать сообщение отдельно
Dani
1263 / 621 / 50
Регистрация: 11.08.2011
Сообщений: 2,236
Записей в блоге: 2
Завершенные тесты: 1
18.12.2011, 11:15     Поиск кратчайшего пути в графе
Флойд, Дейкстра или Форд-Беллман. Надо только матрицу смежности построить.

Добавлено через 57 секунд
Дейкстра
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
41
42
43
44
45
46
47
48
49
50
51
#include <fstream>
#include <algorithm>
#include <vector>
#include <iostream>
int main()
{
   //**********************************************************************
    int a[500][500],d[500]={0},n,s,f,flag[500],l,min1=100000000,nmin=0;
    for (int i=0;i<=500;i++) flag[i]=1;
    std:: ifstream ifs ("input.txt");
    ifs >> n >> s >> f;
    for (int i=1;i<=n;i++)
    for (int j=1;j<=n;j++)//ввод
    {
     ifs >> a[i][j];
     if (a[i][j]==-1 && i!=j) a[i][j]=32000;
    }
    ifs.close();
    //*********************************************************************
    l=s;
    for (int i=1;i<=n;i++) d[i]=a[l][i];//задание начальных значений массиву d
    flag[l]=0;
    
    for (int i=1;i<=n-1;i++)
    {
        min1=100000000;
        nmin=l;
        for (int j=1;j<=n;j++)
        if (flag[j]!=0 && min1>d[j]) 
        { 
           min1=d[j]; 
           nmin=j; 
        } // ищем ближайшую вершину
        
        l=nmin;
        
        flag[l]=0;
        
        for (int j=1;j<=n;j++)
        if (flag[j]!=0) 
        d[j]=std:: min (d[j],a[l][j]+d[l]); //минимальное расстояние до d[j]
        
    }
    
    
    std:: ofstream ofs ("output.txt");
    if (d[f]==32000) ofs << "-1";
    else ofs << d[f];
    ofs.close();
    return 0;
}


Флойд
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
#include <fstream>
#include <algorithm>
int main()
{
    int n, a[101][101];
    std:: ifstream ifs ("input.txt");
    ifs >> n;
    for (int i=1;i<=n;i++)
    for (int j=1;j<=n;j++)
    ifs >> a[i][j];
    ifs.close();
    for (int k=1;k<=n;k++)
    for (int i=1;i<=n;i++)
    for (int j=1;j<=n;j++)
    a[i][j]=std:: min (a[i][j],a[i][k]+a[k][j]);
    std:: ofstream ofs ("output.txt");
    for (int i=1;i<=n;i++)
    {
      for (int j=1;j<=n;j++)
      ofs << a[i][j] << " ";
      ofs << '\n';
    }
    ofs.close();
    return 0;
}


Добавлено через 2 минуты
А графику уже достроите
 
Текущее время: 01:15. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru