Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
 Аватар для 6o6ep4ik
-8 / 1 / 1
Регистрация: 23.10.2015
Сообщений: 175

Алгоритм нахождения всех мостов графа

12.10.2016, 09:32. Показов 1563. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно использовать матрицу смежности.
Можно ли это реализовать так: строится матрица смежности [nxn].
Проставляются значения. (или определенная матрица и определенные значения).
А потом алгоритм пытается удалить одно ребро и проверяет, действительно ли это мост.
Если удалить одно ребро, то нельзя будет попасть в другую вершину. Это и будет мостом.
Мысли, определения верные? Посоветуйте что-нибудь пожалуйста.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.10.2016, 09:32
Ответы с готовыми решениями:

Построить алгоритм прохождения всех циклов графа
Задан граф G=(V,R) из N связанных вершин. Построить алгоритм прохождения всех циклов графа. С++ Примечание: цикл – это замкнутое...

Алгоритм для поиска всех путей между 2 вершинами графа
Здравствуйте, возник вопрос какой алгоритм необходимо использовать для поиска всех путей, между 2 вершинами графа.

Алгоритм нахождения всех возрастающих комбинаций
Доброго время суток форумчане. Встретил задачу над корой бьюсь уже второй день, направьте мои мысли в нужное русло) Условие тяжелое для...

10
1443 / 1326 / 131
Регистрация: 20.03.2009
Сообщений: 4,689
Записей в блоге: 11
12.10.2016, 12:34
Роберт Седжвик Алгоритмы на C++
0
 Аватар для 6o6ep4ik
-8 / 1 / 1
Регистрация: 23.10.2015
Сообщений: 175
12.10.2016, 18:33  [ТС]
Dmitriy_M, книга это, конечно, хорошо, но не то что мне нужно. Я хочу понять, что я должен сделать, и правильно ли я мыслю.
0
15.10.2016, 21:12

Не по теме:

Цитата Сообщение от 6o6ep4ik Посмотреть сообщение
книга это, конечно, хорошо, но не то что мне нужно.
Тогда может бухло и наркотики помогут?
Цитата Сообщение от 6o6ep4ik Посмотреть сообщение
Я хочу понять что я должен сделать и правильно я мыслю.
Мыслите уже хорошо ))

PS: Может все же удастся вас уговорить по хорошему посмотреть книгу )))

0
 Аватар для 6o6ep4ik
-8 / 1 / 1
Регистрация: 23.10.2015
Сообщений: 175
15.10.2016, 21:33  [ТС]
Avazart,

Не по теме:

да, я уже пролистал половину сегодня (книги), завтра внимательно этим вопросом займусь.

p.s. ошибся, должно было быть написано: правильно ли я мыслю

0
15.10.2016, 22:13

Не по теме:

Цитата Сообщение от 6o6ep4ik Посмотреть сообщение
p.s. ошибся, должно было быть написано: правильно ли я мыслю
Исправил.

0
 Аватар для 6o6ep4ik
-8 / 1 / 1
Регистрация: 23.10.2015
Сообщений: 175
16.10.2016, 14:24  [ТС]
Как исправить ошибки:
Ошибка (активно) class "std::vector<int, std::allocator<int>>" не содержит члена "pb" (строка 51, 64)
Ошибка C2039 pb: не является членом "std::vector<int,std::allocator<_Ty> >" (строка 55, 68)

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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#include <vector>
#include <iostream>
using namespace std;
 
const int MAXN = ... ; //максимальное возможное количество вершин во входном графе
 
int n, bridges, par[MAXN], bl[MAXN], comp[MAXN], sizen[MAXN];
 
void init() {
    for (int i = 0; i<n; ++i) {
        bl[i] = comp[i] = i;
        sizen[i] = 1;
        par[i] = -1;
    }
    bridges = 0;
}
 
int get(int v) {
    if (v == -1)  return -1;
    return bl[v] == v ? v : bl[v] = get(bl[v]);
}
 
int get_comp(int v) {
    v = get(v);
    return comp[v] == v ? v : comp[v] = get_comp(comp[v]);
}
 
void make_root(int v) {
    v = get(v);
    int root = v,
        child = -1;
    while (v != -1) {
        int p = get(par[v]);
        par[v] = child;
        comp[v] = root;
        child = v;  v = p;
    }
    sizen[root] = sizen[child];
}
 
int cu, u[MAXN];
 
void merge_path(int a, int b) {
    ++cu;
 
    vector<int> va, vb;
    int lca = -1;
    for (;;) {
        if (a != -1) {
            a = get(a);
            va.pb(a);
 
            if (u[a] == cu) {
                lca = a;
                break;
            }
            u[a] = cu;
 
            a = par[a];
        }
 
        if (b != -1) {
            b = get(b);
            vb.pb(b);
 
            if (u[b] == cu) {
                lca = b;
                break;
            }
            u[b] = cu;
 
            b = par[b];
        }
    }
 
    for (size_t i = 0; i<va.size(); ++i) {
        bl[va[i]] = lca;
        if (va[i] == lca)  break;
        --bridges;
    }
    for (size_t i = 0; i<vb.size(); ++i) {
        bl[vb[i]] = lca;
        if (vb[i] == lca)  break;
        --bridges;
    }
}
 
void add_edge(int a, int b) {
    a = get(a);   b = get(b);
    if (a == b)  return;
 
    int ca = get_comp(a),
        cb = get_comp(b);
    if (ca != cb) {
        ++bridges;
        if (sizen[ca] > sizen[cb]) {
            swap(a, b);
            swap(ca, cb);
        }
        make_root(a);
        par[a] = comp[a] = b;
        sizen[cb] += sizen[a];
    }
    else
        merge_path(a, b);
}
0
Эксперт С++
 Аватар для Avazart
8484 / 6151 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
16.10.2016, 14:36
Цитата Сообщение от 6o6ep4ik Посмотреть сообщение
Как исправить ошибки:
Ошибка (активно) class "std::vector<int, std::allocator<int>>" не содержит члена "pb" (строка 51, 64)
Никак, ибо в векторе нет pb.
Может va.push_back(a) ? Может кто-то гений-сокращений? )))
1
 Аватар для 6o6ep4ik
-8 / 1 / 1
Регистрация: 23.10.2015
Сообщений: 175
16.10.2016, 14:39  [ТС]
Avazart, отлично, а что в main функции писать?
0
Эксперт С++
 Аватар для Avazart
8484 / 6151 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
16.10.2016, 14:40
А мне покуда знать?
0
 Аватар для 6o6ep4ik
-8 / 1 / 1
Регистрация: 23.10.2015
Сообщений: 175
16.10.2016, 14:41  [ТС]
Avazart, а должно быть что там реализовано?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.10.2016, 14:41
Помогаю со студенческими работами здесь

Алгоритм для нахождения всех булевых функций от N переменных
Помогите придумать оптимальный алгоритм для данного условия! очень нужно плиз!!!!!!!(хотя бы для 4)

Алгоритм нахождения радиуса графа
Помогите пж алгоритм определения радиуса графа прога нужна(и если можно с коментами что к чему)

Алгоритм нахождения фактора графа
Уважаемые форумчане прошу помощи в нахождении фактора графа. Нужно найти фактор графа для некоторого произвольного графа. Ну граф я...

Есть какой-нибудь алгоритм для нахождения пары связностей графа
Есть какой нибудь алгоритм для нахождения пары связностей графа?

Алгоритм для поиска всех путей между 2 вершинами графа
здраствуйте помогите написать программу


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru