Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.96/25: Рейтинг темы: голосов - 25, средняя оценка - 4.96
1 / 1 / 0
Регистрация: 17.10.2022
Сообщений: 2
1

Задача на нахождение кратчайшего пути (ориентированный граф)

05.03.2024, 20:37. Показов 4758. Ответов 1

Author24 — интернет-сервис помощи студентам
Всем привет, можете подсказать в чем ошибка? При начальных данных:
4
6
1 2 1
1 3 4
2 3 1
2 4 4
3 4 2
4 1 3
результат должен быть 4, а выводится 9999

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
#include <stdio.h>
 
void a(int graph[100][100], int n, int start, int end) {
    int dist[n][n];
    int i, j, k;
    for (i = 0; i < n; i++) {
        for (j = 0; j < n; j++) {
            dist[i][j] = graph[i][j];
        }
    }
    for (k = 0; k < n; k++) {
        for (i = 0; i < n; i++) {
            for (j = 0; j < n; j++) {
                if (dist[i][k] + dist[k][j] < dist[i][j]) {
                    dist[i][j] = dist[i][k] + dist[k][j];
                } else if (dist[i][k] + dist[k][j] == 9999) {
                    dist[i][j] = 9999;
                }
            }
        }
    }
    printf("Минимальная длина из вершины %d в вершину %d: %d\n", start, end, dist[start][end]);
}
int main() {
    int n, m, start, end;
    int i, j;
    printf("Введите количество вершин: ");
    scanf("%d", &n);
    int graph[100][100];
    for (i = 0; i < n; i++) {
        for (j = 0; j < n; j++) {
            graph[i][j] = 9999;
        }
    }
    printf("Введите количество дуг: ");
    scanf("%d", &m);
    printf("Введите дуги ориентированного графа и их веса:\n");
    for (i = 0; i < m; i++) {
        int u, v, w;
        scanf("%d %d %d", &u, &v, &w);
        graph[u][v] = w;
    }
    printf("Введите начальную вершину: ");
    scanf("%d", &start);
    printf("Введите конечную вершину: ");
    scanf("%d", &end);
    a(graph, n, start, end);
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
05.03.2024, 20:37
Ответы с готовыми решениями:

Граф и реализация алгоритмов нахождения кратчайшего пути
Пожалуста,помогите!Как создать граф в для реализации на нем разных алгоримов нахождения кратчайшего...

Задача на ориентированный граф
Ребята, спасайте! обычно я прихожу сюда с недоделанным кодом/кодом в котором что-то неправильно...

Нахождение кратчайшего пути
Нужно сделать программу,чтоб она находила кратчайший путь от города 1 до города 2 на карте. Как...

Нахождение кратчайшего пути графа
Товарищи программисты! Помогите пожалуйста! Очень нужна программа на С++ Builder для нахождения...

Ориентированный граф, нахождение пути
Помогите пожалуйста, нужно выполнить задания: - все узлы, доступные с заданного за один шаг; - то...

1
Модератор
Эксперт функциональных языков программированияЭксперт Python
37329 / 20761 / 4275
Регистрация: 12.02.2012
Сообщений: 34,167
Записей в блоге: 14
06.03.2024, 11:16 2
Думаю, ошибка в том, что нужно в свободные элементы dist поместить 9999
0
06.03.2024, 11:16
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
06.03.2024, 11:16
Помогаю со студенческими работами здесь

Ориентированный направленный граф. Найти пути из A в B
Л.Р.№3. Рекурсия. Вход: Ориентированный направленный граф. Нагрузка на вершинах; вершины А,B,...

Ориентированный граф, нахождение цикла
Помогите пожалуйста, нужно найти: - все циклы длиной 3; - есть ли гамильтонов цикл. implement...

Задача на ориентированный граф
Очень нужна помощь в решении Задача: источником ориентированного графа назовем вершину, от которой...

Ориентированный взвешенный граф с матрицей смежности: нахождение цикла с минимальной стоимостью
Помогите написать прогу! Главное для меня нахождение циклов в графе, единственное что не знаю....

нахождение кратчайшего пути
из пункта А в пункт Б необходимо проложить трубопровод по самому экомичному пути. Данные приведены...

Нахождение кратчайшего пути
Нужна помощь, нужно найти кратчайший путь от А до В


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru