Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.70/40: Рейтинг темы: голосов - 40, средняя оценка - 4.70
 Аватар для VLaDoS_2001a
319 / 216 / 114
Регистрация: 14.05.2020
Сообщений: 890

Найти цикл в неориентированном графе

01.08.2020, 04:42. Показов 8383. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как можно найти цикл в неориентированном графе. Использовал DFS , он не работает
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.08.2020, 04:42
Ответы с готовыми решениями:

Как найти все циклы в неориентированном графе по ребрам?
Как найти все циклы в неориентированном графе по ребрам?

Существование пути в неориентированном графе
Как должен выглядеть алгоритм который проверяет существует ли путь между 2 вершинами неориентированного графа?

Абсолютные медианы на неориентированном графе
Сильно связный граф G=<V,E>, дугам(ребрам) и вершинам которого приписаны неотрицательные целые веса. Граф задан матрицей весов дуг A,u,v...

5
1293 / 677 / 367
Регистрация: 07.01.2019
Сообщений: 2,302
01.08.2020, 05:46
Цитата Сообщение от VLaDoS_2001a Посмотреть сообщение
Использовал DFS , он не работает
Вроде должен работать https://neerc.ifmo.ru/wiki/ind... 0%BB%D0%B0
0
 Аватар для VLaDoS_2001a
319 / 216 / 114
Регистрация: 14.05.2020
Сообщений: 890
01.08.2020, 18:30  [ТС]
Del

Добавлено через 3 часа 11 минут
tooru,
Как можно модифицировать мой код DFS (у меня проблема с 1->3; 3->1) он считает лишние циклы
C++
1
2
3
4
5
6
7
8
9
10
11
void dfs(int start, vector<vector<int>>&g,
vector<int>&used)
{
    used[start] = 1;
    for(auto&i: g[start])
    {
        if(used[i] == 0) dfs(i,g,used);
        else if(used[i] == 1) ++c;
    }
    used[start] = 2;
}
0
1293 / 677 / 367
Регистрация: 07.01.2019
Сообщений: 2,302
01.08.2020, 21:43
Цитата Сообщение от VLaDoS_2001a Посмотреть сообщение
Как можно модифицировать мой код DFS
Нужен минимальный рабочий пример
0
 Аватар для VLaDoS_2001a
319 / 216 / 114
Регистрация: 14.05.2020
Сообщений: 890
01.08.2020, 21:50  [ТС]
tooru, Ответ 3 а у меня только 2
4 5
1 2
2 3
3 4
4 1
1 3
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
#include <iostream>
#include <vector>
#include <stack>
using namespace std;
 
int c = 0;
 
void dfs(int start, 
vector<int>&used,vector<vector<int>>&g)
{
    stack<pair<int,int>>st;
    st.push(make_pair(start,-1));
    used[start] = 1;
    while(!st.empty())
    {
        int s = st.top().first;
        int f = st.top().second;
        st.pop();
        for(auto&i:g[s])
        {
            if(used[i]==0)
            {
                used[i] = 1;
                st.push(make_pair(i,s));
            }
            else if(i != f) ++c;
        }
        used[start] = 2;
    }   
}
 
int main(void)
{
    int n, m, a, b; cin >> n >> m;
    vector<vector<int>>g(n + 1);
    vector<int>used(n + 1, 0);
    
    for(size_t i = 1; i <= n; ++i)
    {
        cin >> a >> b;
        g[a].emplace_back(b);
        g[b].emplace_back(a);
    }
    
    for(size_t i = 1; i <= n; ++i) {if(used[i]==0) dfs(i,used,g);}
    cout<<c<<endl;  
}
0
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8659 / 4494 / 1669
Регистрация: 01.02.2015
Сообщений: 13,908
Записей в блоге: 12
02.08.2020, 17:34
У меня впечатление, что dfs неправильно реализован - какой-то стек и маркировка узла "чёрным" цветом почему-то не перед завершением программы, а внутри цикла рассмотрения всех связей текущей вершины.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.08.2020, 17:34
Помогаю со студенческими работами здесь

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

Метод поиска в глубину, в неориентированном графе
Добрый день! Помогите решить задание: Используя метод поиска в глубину, в неориентированном графе, найти и вывести все вершины,...

В неориентированном графе посчитать количество компонент связности
2. Компоненты связности В неориентированном графе посчитать количество компонент связности. В графе нет петель и кратных ребер. Формат...

Выведение всех возможных маршрутов в неориентированном графе
Помогите пожалуйста составить программу для выведения всех возможных маршрутов в неориентированном графе

Найти цикл в графе
Дан граф, содержащий только один цикл. Нужно найти его (все его вершины). Код не нужен, нужна только идея.


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru