Форум программистов, компьютерный форум, киберфорум
C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 27.03.2023
Сообщений: 20

Поиск в ширину на неориентированном графе C++

30.09.2023, 18:56. Показов 2002. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
1. Реализовать поиск кратчайшего пути между парой заданных вершин на неориентированном связном графе.
2. Ответить на вопросы:
Что является входом для алгоритма поиска кратчайшего пути на неориентированном связном графе, что – результатом работы?
Какова его вычислительная сложность?
Переносится ли поиск кратчайшего пути (и поиск в ширину) на ориентированные графы?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.09.2023, 18:56
Ответы с готовыми решениями:

Поиск всех циклов в неориентированном графе.
На входе программа принимает номера вершин и вес ребра между ними. Например: 2 3 1 - между вершинами 2 и 3 есть ребро весом 1. Нужно...

Поиск в ширину на графе
#include "stdafx.h" #include "stdafx.h" #include <iostream> #include <conio.h> #include<vector> #include<queue> using namespace...

Реализовать поиск в ширину в простом графе
Поиск в ширину--2 (вершины идентифицируются названиями) ограничение по времени на тест: 2 seconds ограничение по памяти на тест: 64...

1
20 / 12 / 8
Регистрация: 30.10.2023
Сообщений: 32
30.10.2023, 17:31
Лучший ответ Сообщение было отмечено gfdhiiii как решение

Решение

2. Вход - граф, начальная (и конечная, если надо) вершины. Выход - кратчайшее расстояние от вершины до всех остальных.
Вычислительная сложность - O(V + E), где V - кол-во вершин, E - кол-во ребер.
Да, переносится на ориентированные графы.

1.
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 <iostream>
#include <queue>
#include <vector>
#include <stdint.h>
 
constexpr int INF = INT32_MAX;
 
std::vector <int> BFS(const std::vector <std::vector <int> >& graph, int start) {
    int n = graph.size();
    std::queue <int> q;
    std::vector <int> result(n, INF);
    result[start] = 0;
    q.push(start);
    while (!q.empty()) {
        auto cur = q.front();
        q.pop();
        for (auto to : graph[cur]) {
            if (result[to] > result[cur] + 1) {
                result[to] = result[cur] + 1;
                q.push(to);
            }
        }
    }
    return result;
}
 
signed main() {
    int n;
    std::cout << "Enter vertexes amount:\n";
    std::cin >> n;
    std::vector <std::vector <int> > graph(n);
    int m;
    std::cout << "Enter edges amount:\n";
    std::cin >> m;
    std::cout << "Enter edges [a, b] (1 <= a, b <= n):\n";
    for (int i = 0; i < m; ++i) {
        int a, b;
        std::cin >> a >> b;
        --a, --b;
        graph[a].push_back(b);
        graph[b].push_back(a);
    }
    std::cout << "Enter start and finish vertexes (1 <= begin, end <= n):\n";
    int begin, end;
    std::cin >> begin >> end;
    --begin, --end;
    std::vector <int> dist = BFS(graph, begin);
    std::cout << dist[end];
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
30.10.2023, 17:31
Помогаю со студенческими работами здесь

Найти длину минимального пути между двумя вершинами в неориентированном графе (поиск в ширину)
В неориентированном графе требуется найти длину минимального пути между двумя вершинами. Гарантируется, что путь существует. Входные...

Методом поиска в ширину найти и вывести путь в неориентированном графе между двумя вершинами
Методом поиска в ширину найти и вывести путь в неориентированном графе между двумя вершинами. Номера начальной и конечной вершины ввести с...

Поиск пути в неориентированном графе
{Задача: имеется N населенных пунктов. Некоторые пары пунктов соединены дорогами требуется определить можно ли из пункта с номером...

ФРЛ, поиск в неориентированном графе
Пoмoгитe, пoжaлуйcтa, зa бoльшoe чeлoвeчecкoe cпacибo и.. сможем договориться о размерах спасиба Реализовать функцию, кoтoрaя...

Поиск компонент вершинной двусвязности в неориентированном графе
Пытаюсь реализовать этот алгоритм -...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru