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

Алгоритм Дейкстры - C++

Восстановить пароль Регистрация
 
Niсe
 Аватар для Niсe
1 / 1 / 0
Регистрация: 09.12.2009
Сообщений: 30
24.02.2012, 13:27     Алгоритм Дейкстры #1
"Для заданных n(1<=n<=500), m(1<=m<=n*n), v1 v2(1<=v1,v2<=n), где n-число вершин неор графа, m - количество ребер, v1 стартовая вершина v2 конечная вершина, найти кратчайшее расстояние от v1 до v2.
Входные данные
первая строка - n m v1 v2
далее m строк с описанием ребер.
Выходные данные - искомая длина"
Пример
Ввод
2 1 1 2
2 1 2
Вывод
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
41
42
43
44
45
46
47
48
49
50
51
52
53
#include <iostream>
using namespace std;
const int inf = 255555555;
int main()
{
    int n, m, v1, v2, sourse, finish, dl, min;
    bool temp;
    cin>>n>>m>>v1>>v2;
    int ** graf = new int *[n];
    for(int i = 0; i < n; i++)
        graf[i] = new int [n];
    int *d=  new int[n];
    bool *used = new bool [n];
    for(int i = 0; i < n; i++)
        used[i]= 0;
    for(int i = 0; i < n; i++)
        d[i] = inf;
    for(int i = 0; i < n; i++)
        for(int j = 0; j < n; j++)
            graf[i][j]= inf;
    for(int i = 0; i < m; i++)
    {
        cin>>sourse>>finish>>dl;
        graf[sourse-1][finish-1]= dl;
        graf[finish-1][sourse-1]= dl;
    }
    d[v1-1]=0;
    while(true)
    {
        temp = false;
        min = 3*inf;
        for(int i = 0; i < n; i++)
            if(d[i]<min && !used[i]) 
            {
                min = i;
                temp= true;
            }
        if(!temp) break;
        used[min] = true;
        for(int i = 0; i < n; i++)
            if(d[i]>d[min]+graf[min][i])
                d[i]= d[min]+graf[min][i];
 
        
    }
        cout<<d[v2-1];
    delete[] used;
    delete[] d;
    for(int i = 0; i < n; i++)
    delete[] graf[i];
    delete[] graf;
    return 0;
}
Добавлено через 1 час 6 минут
"Для заданных n(1<=n<=500), m(1<=m<=n*n), v1 v2(1<=v1,v2<=n), где n-число вершин неор графа, m - количество ребер, v1 стартовая вершина v2 конечная вершина, найти кратчайшее расстояние от v1 до v2.
Входные данные
первая строка - n m v1 v2
далее m строк с описанием ребер.
Выходные данные - искомая длина, если пути не существует вывести -1"
Пример
Ввод
2 1 1 2
2 1 2
Вывод
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include <iostream>
using namespace std;
const int inf = 255555555;
int main()
{
    int n, m, v1, v2, sourse, finish, dl, min;
    bool temp;
    cin>>n>>m>>v1>>v2;
    int ** graf = new int *[n];
    for(int i = 0; i < n; i++)
        graf[i] = new int [n];
    int *d=  new int[n];
    bool *used = new bool [n];
    for(int i = 0; i < n; i++)
        used[i]= 0;
    for(int i = 0; i < n; i++)
        d[i] = inf;
    for(int i = 0; i < n; i++)
        for(int j = 0; j < n; j++)
            graf[i][j]= inf;
    for(int i = 0; i < m; i++)
    {
        cin>>sourse>>finish>>dl;
        graf[sourse-1][finish-1]= dl;
        graf[finish-1][sourse-1]= dl;
    }
    d[v1-1]=0;
    while(true)
    {
        temp = false;
        min = inf/2;
        for(int i = 0; i < n; i++)
            if(d[i]<min && !used[i]) 
            {
                min = i;
                temp= true;
            }
        if(!temp) break;
        used[min] = true;
        for(int i = 0; i < n; i++)
            if(d[i]>d[min]+graf[min][i])
                d[i]= d[min]+graf[min][i];
 
        
    }
        if(d[v2-1]>inf/2) cout<<"-1";
        else cout<<d[v2-1];
    delete[] used;
    delete[] d;
    for(int i = 0; i < n; i++)
    delete[] graf[i];
    delete[] graf;
    return 0;
}
проглядел, что если нет пути - нужно выводить -1, изменил, но и это не помогает
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.02.2012, 13:27     Алгоритм Дейкстры
Посмотрите здесь:

Алгоритм Дейкстры C++
Алгоритм Дейкстры C++
Алгоритм Дейкстры C++
C++ Алгоритм Дейкстры
C++ Алгоритм Дейкстры
Алгоритм Дейкстры C++
Алгоритм Дейкстры C++
C++ Алгоритм Дейкстры

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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