Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.96/56: Рейтинг темы: голосов - 56, средняя оценка - 4.96
308 / 61 / 12
Регистрация: 21.12.2011
Сообщений: 290

Обход вершин графа в глубину стеком

05.06.2013, 07:30. Показов 10527. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Применить стек для обхода вершин графа, заданного с помощью матрицы смежности, в глубину.

Есть код.. Но он не совсем правильно работает.. Как вывести порядок обхода? Т.е. весь маршрут.. К примеру 2->4->3->1

stack.h:
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
#define STACK struct stack
 
STACK
{
   int info ;
   STACK *next ;
};
 
extern void push( STACK **s, int item);
extern int pop ( STACK **s);
extern int peek( STACK **s);
 
void push (STACK **s, int item)//Добавление элемента
{
   STACK *new_item; 
   new_item = (STACK *) malloc (sizeof(STACK));
   new_item -> info = item;
   new_item -> next = *s ;
   *s = new_item;
}
 
int pop (STACK **s)//Удаление элемента
{
   int error;
   STACK *old_item = *s;
   int old_info = 0;
   if ( *s )
   {
      old_info = old_item -> info;
      *s = ( *s ) -> next;
      free (old_item );
      error = 0;
   }
   else error = 1;
   return ( old_info );
}
int take_out (STACK **s, int *error)
{
   STACK *old_item = *s ;//начало очереди
   int old_info = 0 ;
   if (*s)//если очередь не пуста
   {
      old_info = old_item -> info;
      *s = ( *s ) -> next;
      free (old_item );//уничтожение элемента
      *error = 0;
   } else *error = 1;
   return (old_info);
}
 
 
int peek (STACK **s)//Чтение элемента 
{
   int error;
   if (*s)
   {
      error = 0; return (*s) -> info;
   }
   else
   {
      error = 1; return 0;
   }
}
void show_stack(stack *s)//Печать стека
{
   printf("\n");
   if (s)
   {
      printf(" %d ", s->info); show_stack(s->next);
   }
}
 
int isempty( STACK **s)
{
   if (*s) return 0;//если непусто
   else return 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
#include "stdafx.h"
#include <iostream>
#include <math.h>
#include "stack.h"
 
int i,j,z,x,m;
int p=0;
int b[8];
int k=0;
int c[8];
int n=8;                  // номера предшествующих вершин
int a[8][8]={ 
          0,1,1,0,0,0,0,0, // матрица смежности
          1,0,0,0,0,0,1,0,
          1,0,0,1,0,0,0,0,
          0,0,1,0,1,1,0,0,
          0,0,0,1,0,0,1,1,
          0,0,0,1,0,0,1,0,
          0,1,0,0,1,1,0,0,
          0,0,0,0,1,0,0,0 };
 
int main()
{
    setlocale(LC_ALL,"");
    /*STACK *s1 = 0, *s2 = 0;
    int *error;
    push (&s1, p);//добавить
    printf("Добавили в стек %d", p);
    printf("\nУдалили из стека %d", pop (&s1));
    for (i=0; i<n; i++)
    {
        for (p=0; p<n; p++)
        {
            if (a[i][p]==1)//если ячейка матрицы = 1
            {
                push (&s1, p);//добавить
                printf("\nДобавили в стек %d", p);
            }
        }
        printf("\nУдалили из стека %d", pop (&s1));
    }
    getchar();*/
 
    return 0;
}
Добавлено через 18 часов 29 минут
Проблема актуальна
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.06.2013, 07:30
Ответы с готовыми решениями:

Обход графа в глубину
Доброго времени суток, братцы! Есть такая задачка - обойти граф в глубину. Сам алгоритм примерно понятен, но проблема именно с тем, чтобы...

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

Обход графа в глубину
Покажите кто-нибудь как работает &quot;обход графа&quot; в графе в консоле А именно вывод глубины графа,сколько ребер обошел ,где был уже... ...

2
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
05.06.2013, 07:40
Делал когда-то
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
#include <fstream>
#include <stack>
#include <vector>
#include <iostream>
#include <clocale>
#define N 10
using namespace std;
 
void designing(int* , int, int, ofstream&); // конструирование маршрута
 
int main()
{
    setlocale(LC_ALL, "Russian");
    ofstream o("result.txt");
    ifstream in("A.txt");
    if (!in) return 1;
    // ------------------------------инициализация------------------------------
    stack <int> st; // стек для хранения номеров вершин
    bool instack[N]; //false - вершина не в стеке, true - в стеке
    bool DUG[N][N]; // матрица смежности
    int start, end; // номер стартовой и конечной вершин
    int rang[N]; // длина пути
    int VON_PUNKT[N]; // номер вершины, из которой попали в текущую
    cout<< "Введите начальную вершину: ";
    do{ cin>> start;} while (start < 0 || start > 9);
    cout<< "Введите конечную вершину: ";
    do{ cin>> end;} while (end < 0 || end > 9 || end == start);
    for (int i = 0; i < N; i++)
    {
        VON_PUNKT[i] = start;
        rang[i] = 999;
        instack[i] = false;
        for (int j = 0; j < N; j++)
            in>> DUG[i][j];
    }
    // записываем начальную вершину в очередь
    st.push (start);
    instack[start] = true;
    VON_PUNKT[start] = -1;
    rang[start] = 0;
    // --------------------------------общий шаг--------------------------------
    while (!st.empty())
    {
          int besuch = st.top();
          st.pop();
          for (int i = 0; i < N; i++)
          {
              if (!instack[i] && DUG[besuch][i])
              {
                  st.push (i);
                  instack[i] = true;
                  rang[i] = rang[besuch] + 1;
                  VON_PUNKT[i] = besuch;
              }
          }
    }
    // --------------------------запись пути в файл ----------------------------
    designing(VON_PUNKT, rang[end], end, o);
    in.close();  o.close();
    return 0;
}
 
void designing(int *p, int rang, int end, ofstream &o)
{
    vector <int> v;
    vector <int>::iterator cur;
    for (int i = end; i != -1; i = p[i])
        v.push_back(i);
    o<< "Количество переходов: "<< rang<< endl;
    for (cur = v.end() - 1; cur >= v.begin(); cur--)
        o<< *cur<< " ";
}
Матрица смежности:
Code
1
2
3
4
5
6
7
8
9
10
0 0 0 1 0 1 0 0 0 0
0 0 1 0 1 0 0 0 0 0
0 1 0 0 0 0 1 0 1 0
1 0 0 0 0 1 0 1 0 0
0 1 0 0 0 1 1 0 0 0
1 0 0 1 1 0 0 0 0 0
0 0 1 0 1 0 0 0 0 0
0 0 0 1 0 0 0 0 0 1
0 0 1 0 0 0 0 0 0 1
0 0 0 0 0 0 0 1 1 0
1
308 / 61 / 12
Регистрация: 21.12.2011
Сообщений: 290
05.06.2013, 11:57  [ТС]
MrGluck, спасибо... работает! завтра пойду сдавать)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.06.2013, 11:57
Помогаю со студенческими работами здесь

Обход графа в глубину
Как сделать обход этого графа в глубину ?

Обход неориентированного графа в глубину
#include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;vector&gt; #include &lt;conio.h&gt; #include &lt;locale.h&gt; using namespace std; int...

Многопоточный обход графа в глубину
Доброго времени суток. Подскажите многопоточный алгоритм обхода графа в глубину (нужно распараллелить алгоритм поиска компонент связности)....

Обход графа в ширину для определения всех вершин графа, находящихся на фиксированном расстоянии от данной вершины
Реализуйте обход графа в ширину для определения всех вершин графа, находящихся на фиксированном расстоянии d от данной вершины. HELP

Паттерн Итератор. Обход графа в глубину
Имею данный алгоритм обхода графа в глубину. Необходимо реализовать данную задачу с помощью паттерна Итератор и используя цикл foreach. ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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 - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru