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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ решения, которые получаются перестановкой размеров сторон считать одинаковыми http://www.cyberforum.ru/cpp-beginners/thread451871.html
Очень нужно реализовать прграмму на Паскале. Вопрос вызывает только вторая часть задачи. Не могу описать "исключение".Помогите пожалуйста. Найти размеры всех прямоугольников, площадь которых равна заданному натуральному числу S и стороны которых выражены натуральными числами. При этом решения, которые получаются перестановкой размеров сторон считать одинаковыми.
C++ Классы Разработать консольную программу на языке С++, в которой описывается и используется простой класс для объектов индивидуального варианта. Поля данных класса должны быть закрытыми, а доступ к ним должен осуществляться с помощью открытых методов. Кроме полей с данными в классе должны быть конструкторы, деструктор и другие методы класса в соответствии с заданием. Создать массив объектов. ... http://www.cyberforum.ru/cpp-beginners/thread451851.html
C++ Форматированный вывод
Например: double a=3.00; cout << a; выводит 3 А мне нужно (таково условие вывода в задаче), чтобы выводило именно 3.00 То есть, чтобы выводило в обычной (не scientific) записи округлённое число именно до сотых. И чтобы обязательно выводило два десятичных знака после запятой, даже если это нули. Как это сделать. Помогите, пожалуста. Экспериментировал c precision, ceil, floor......
C++ Игра "Жизнь"
Игра "Жизнь" Игра моделирует жизнь поколений гипотетической колонии живых клеток, которые выживают, размножаются или погибают в соответствии со следующими правилами: Клетка выживает в следующем поколении, если у нее 2 или 3 соседа из 8 возможных. Если у клетки только один сосед или ни одного, она погибает в изоляции. Если клетка имеет четырех и более соседей, она погибает от перенаселения. Новая...
C++ Ошибка Е2379 http://www.cyberforum.ru/cpp-beginners/thread451804.html
#include <vcl.h> #pragma hdrstop #pragma <stdio.h> #include <conio.h> //--------------------------------------------------------------------------- #pragma package(smart_init) #pragma resource "*.dfm" //---------------------------------------------------------------------------
C++ Сортировка с пузырём Здравствуйте. Начал изучать сортировки, хотел написать свой "пузырек", а оно чего-то работать не хочет, зацикливается. Поглядите, пожалуйста: #include <iostream> using namespace std; void printArray( int, int ); void bubbleSort( int, int ); void swap( int, int ); int main() подробнее

Показать сообщение отдельно
Niсe
 Аватар для Niсe
1 / 1 / 0
Регистрация: 09.12.2009
Сообщений: 30
24.02.2012, 13:27     Алгоритм Дейкстры
"Для заданных 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, изменил, но и это не помогает
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 15:10. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru