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

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

Войти
Регистрация
Восстановить пароль
 
Niсe
1 / 1 / 0
Регистрация: 09.12.2009
Сообщений: 30
#1

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

24.02.2012, 13:27. Просмотров 457. Ответов 0
Метки нет (Все метки)

"Для заданных 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++
Ребятушки, помогите, пожалуйста. Нужна реализация алгоритма дейкстры на паскале, а именно вот этого кода const int INF = 1000000000; ...

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

Алгоритм Дейкстры - C++
Что-то у меня Дейкстра не работает... прошу помощи у вас... Сам уже часа 1.5 сижу и не могу найти ошибку...#include &lt;iostream&gt; #include...

Алгоритм Дейкстры - C++
День добрый! Есть игровое поле M*M. Количесво графов - N. Есть матрица смежности этого игрового поля. Получить элемент матрицы можно...

Алгоритм Дейкстры - C++
Пытаюсь сейчас его понять, как я понял сперва надо оставить матрицу смежности, и все возможные связи между вершинами заполнить их длинами,...

Алгоритм Дейкстры - C++
Всем добрый день,уважаемые программисты! Помогите пожалуйста решить вот эту задачу алгоритмом дейкстры. Вроде сам алгоритм правильно...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.02.2012, 13:27
Привет! Вот еще темы с ответами:

Алгоритм Дейкстры С++ - C++
Реализовать алгоритм поиска кратчайшего пути. Алгоритм Дейкстры. Представление графа – матрица смежности. как можно после того как...

Алгоритм Дейкстры - C++
Помогите найти ошибку плз. Первый шаг алгоритма выполняет правильно,а дальше-нет. #include&lt;iostream&gt; #include&lt;fstream&gt; ...

Алгоритм Дейкстры - C++
Как на С++ в консольном приложении описать алгоритм Дейкстры?

Алгоритм Дейкстры - C++
Добрый день, помогите пож-та решить задачи на с++. Нашел решение (расписаны все алгоритмы, процедуры подсчета и т. д.), но сложность...


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

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

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