Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Пример задания с сайта Яндекса =) Доброе время суток всем страждущим :jokingly: Просматривая объявления вакансий для программистов не мог не заметить некую шаблонность что-ли, этих самых объявлений. В них говориться что нужен специалист, профессионал. Владение стандартными алгоритмами, знание основных структур данных :D , знание ООП и умение применять его на практике и тд... А кто он ? Этот самый профессионал ? В моем... https://www.cyberforum.ru/ cpp-beginners/ thread344254.html C++ Найти следующее после n число, в двоичной записи которого столько же единиц
Доброго времени суток. Вопрос в названии темы, полное условие тут. Перебор не проходит. Пробовал #include <iostream> int ones_count(int n){ int res = 0; for( ; n ; n >>= 1) res += n & 1; return res; }
C++ Класс дата Создать класс типа - дата с полями: день (1-31), месяц (1-12), год(целое число).Класс имеет конструктор:с параметрами, без параметров,копирования; деструктор; функции-члены получения дня,месяца и года,а также две функции-члены печати по шаблону: "5 января 1997 года" и "05.01.1997"; функции-члены должны проверять корректность задаваемых параметров. Помогите пожалуйста с определением класса! Вот... https://www.cyberforum.ru/ cpp-beginners/ thread344218.html C++ CodeLite - отсутствуют библиотеки https://www.cyberforum.ru/ cpp-beginners/ thread344179.html
Здравствуйте, дорогие форумчане. Необходима кросcплатформенная среда разработки C++. На рабочем компе через центр приложений (Ubuntu) поставил CodeLite. Столкнулся с проблемой отсутствия инклудов windows.h, conio.h и т.д. Проекты просто не запускаются. На домашнем ПК пользуюсь Visual Studio, поэтому с подобной проблемой никогда не сталкивался. В инете манов по это поводу не нашел. Прошу...
C++ Получить список студентов с указанием среднего балла
имеется информация о студентах группы: Ф.И.О., результаты экзаменационной сессии. Мне надо получить список студентов с указанием среднего балла. Для решения данной задачи мне надо использовать массив структур или можно как-то по другому сделать? Если да, то как?
C++ Код ждёт ввода следующей строчки - цикл повторяется бесконечно. https://www.cyberforum.ru/ cpp-beginners/ thread344173.html
В учебнике написано, что вот этот код #include <iostream> #include <string> using namespace std; int main() { string word; while (cin >> word) cout << "прочитано слово: " << word << "\n";
C++ Как сменить IP адрес день добрый. не подскажите как программно заставить венду сменить IP ? https://www.cyberforum.ru/ cpp-beginners/ thread344162.html Немного о динамическом выделении памяти ... C++
объявление данных в классе: class Employee {.......... private: char *firstName; char *lasrName; }
C++ помогите с islower() и setfill() https://www.cyberforum.ru/ cpp-beginners/ thread344111.html
1)Библиотечная функция islower() принимает в качестве аргумента один символ (букву) и возвращает ненулевое целое значение в том случае, если буква является строчной, и нулевое, если буква является заглавной.Описание функции хранится в файле CTYPE.H.Напишите программу, которая принимает букву от пользователя, а затем выводит нулевое или ненулевое значение в зависимости он того, является буква...
C++ Запись условия Здравствуйте, не подскажите как правильно записать условие, если скажем есть int a и оно должно быть равно 1 или 5: if(a== (1||5) \\or if(a==1||5) Может я что-то делал не так, но у меня ни один из этих методов не работал, или надо только так писать: if (a==1 || a==5)? Заранее спасибо! https://www.cyberforum.ru/ cpp-beginners/ thread344058.html
C++ может не в тот раздел поместил
вопрос
C++ Исследование структуры FILE или: что вообще можно выудить из этой структуры, указатель на которую мы получаем при открытии файла? https://www.cyberforum.ru/ cpp-beginners/ thread344039.html
Ничего нельзя. Итак, новичкам напомню, что после выполнения кода FILE* f= fopen ("file.txt", "w"); в переменной f содержится указатель на структуру FILE. Если файл file.txt открыт корректно, то, по логике вещей *f некоторым образом должна описывать открытый file.txt. Размер там, имя, адрес в памяти, куда файл спроецирован хоть что-то. Так, в инете я не нашёл по этой структуре ничего, но в...
Заблокирован
Автор FAQ
22.08.2011, 16:26 0

Удаление цикла в ориентированном графе - C++ - Ответ 1931531

22.08.2011, 16:26. Показов 4673. Ответов 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
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
#include <iostream.h>
 
void rem_circules(int n, int * left, int * right);
void repl_vershini(int n, int i, int rem1, int rem2, int repl, int * left, int * right);
 
int main()
{
    char ch;
    int i,n,*left,*right;
    do
    {
        cout<<"Vvedite chislo vetvei grapha: ";
        cin>>n;
        left  = new int[n];
        right = new int[n];
 
        cout<<"\tVvod vetvei\r\n";
        for(i = 0; i < n; i++)
        {
            cout<<"\t Vetv' ["<<i + 1<<"]\r\n";
            cout<<"left = ";cin>>left[i];
            cout<<"right= ";cin>>right[i];
        }
        cout<<"Vid grapha\r\n";
        for(i = 0; i < n; i++)
            cout<<left[i]<<" "<<right[i]<<"\r\n";
        cout<<"Rem circules\r\n";
        rem_circules(n, left, right);
        cout<<"Vid grapha\r\n";
        for(i = 0; i < n; i++)
            cout<<left[i]<<" "<<right[i]<<"\r\n";
 
        cout<<"Rem dubli\r\n";
        cout<<"Vid grapha\r\n";
        for(i = 0; i < n; i++)
        {
            if(left[i] != right[i])
                cout<<left[i]<<" "<<right[i]<<"\r\n";
        }
 
        delete [] left;
        delete [] right;
        cout<<"Y - New input\r\n";
        cin>>ch;
    }
    while(ch == 'Y' || ch == 'y');
    return 0;
}
 
void rem_circules(int n, int * left, int * right)
{
    for(int i = 0,j; i < n; i++)
    {
        for(j = i; j < n; j++)
        {
            if(
                right[i] + 1 == left[j] && 
                left[i] == right[j] && 
                left[i] != left[j])
            {
                cout<<"Circle naiden v vetvi["<<j + 1<<"]\r\n";
                repl_vershini(n, i, right[i], left[j], left[i], left, right);
                right[i] = left[i];
            }
        }
    }
}
 
void repl_vershini(int n, int i, int rem1, int rem2, int repl, int * left, int * right)
{
    for(int j = 0; j < n; j++)
    {
        if(j != i)
        {
            if(left[j] == rem1 || left[j] == rem2)
                left[j] = repl;
            if(right[j] == rem1 || right[j] == rem2)
                right[j] = repl;
        }
    }
}
[Результат работы]

Vvedite chislo vetvei grapha: 6
Vvod vetvei
Vetv' [1]
left = 1
right= 2
Vetv' [2]
left = 2
right= 3
Vetv' [3]
left = 2
right= 4
Vetv' [4]
left = 3
right= 1
Vetv' [5]
left = 3
right= 5
Vetv' [6]
left = 4
right= 5
Vid grapha
1 2
2 3
2 4
3 1
3 5
4 5
Rem circules
Circle naiden v vetvi[4]
Vid grapha
1 1
1 1
1 4
1 1
1 5
4 5
Rem dubli
Vid grapha
1 4
1 5
4 5
Y - New input


Вернуться к обсуждению:
Удаление цикла в ориентированном графе C++
2
Заказать работу у эксперта
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.08.2011, 16:26
Готовые ответы и решения:

Поиск циклов в ориентированном графе
Доброго времени суток. Может кому-нибудь из вас не составит особого труда, или возможно кто-то...

Поиск всех контуров в ориентированном графе
Нужно найти все контуры. Контур - путь, у которого начало и конец совпадают. Т.е. например...

Алгоритм поиска в глубину в ориентированном графе
Добрый вечер,форумчане:) Знаю, что подобная тема встречалась тут довольно часто, но у меня все-таки...

Класс для поиска простых контуров на ориентированном графе
Ребят, помогите прогу написать :gsorry: завтра сдавать, а я не знаю ничего совсем :gsorry::gcray: ...

1
22.08.2011, 16:26
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.08.2011, 16:26
Помогаю со студенческими работами здесь

Ранжирование вершин на ориентированном графе без контуров по отношению к вершине
Помогите сделать алгоритм по данному коду. Задание: Написать и исследовать программу,...

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

Нахождение отрицательного цикла в графе и вывод цикла
Вот программа по нахождению отрицательного цикла в графе и вывод цикла void Floyd(int GR, int...

Поиск отрицательного цикла (контура) в графе
Всем привет! Помоги пожалуйста с программой! :-mass), затем я её модифицирую: for (int i = 0; i &lt;...

0
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru