Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 31, средняя оценка - 4.68
Legendary
Сообщений: n/a
#1

поиск в ширину - C++

21.05.2010, 06:37. Просмотров 3781. Ответов 2
Метки нет (Все метки)

Помогите объяснить это по русски каждую строчку что тут написнао .
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
#include <cstdio>
#include <vector>
#include <stack.h>
#include <queue>
#include <list>
using namespace std;
struct Ver
{
int v, w;
};
 
//------------------------------------------------------------------------------
 
vector<vector<Ver> > Graf;
vector<vector<Ver> > Carcas;
vector<bool> isl_p;
stack<int> st_p_g;
queue<int> st_p_w;
 
 
 
 
void psk_deep()
{
int k=st_p_g.top();
isl_p[k]=true;
for (int i=0; i < Graf[k].size(); i++)
{
 if (isl_p[Graf[k][i].v] == false)
 {
  printf ("%d -> %d\n", k, Graf[k][i].v);
  st_p_g.push(Graf[k][i].v);
  psk_deep();
  st_p_g.pop();
 }
}
}
 
void poisk_deep(int k)
{
printf("-----------------------------------Poisk v glubinu-------------------------\n");
isl_p.resize(Graf.size());
st_p_g.push(k);
psk_deep ();
st_p_g.pop();
for (int i=0; i < isl_p.size(); i++) isl_p[i]=false;
printf("\n");
}
 
//------------------------------------------------------------------------------
общий смысл понятен ,не понятно как переходят и что за стандартные функции типо Graf.size , st_p_g.pop();

C++
1
2
3
4
5
vector<vector<Ver> > Graf;
vector<vector<Ver> > Carcas;
vector<bool> isl_p;
stack<int> st_p_g;
queue<int> st_p_w;
Помогите пожалуйста ..не омгу сам уже разобраться.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.05.2010, 06:37     поиск в ширину
Посмотрите здесь:

Поиск в ширину - C++
Здравствуйте, я ознакомился с поиском в ширину в общем виде, знаю принцип работы, для чего используеться, но задаюсь вопросом об...

Поиск в ширину - C++
Можете, пожалуйста, объяснить как понять вот этот код: vector &lt; vector&lt;int&gt; &gt; g; // граф непонятно, как описан вектор. код взят...

поиск в ширину(Рекурсивный) - C++
Программа запускается но выдает ошибку(Задача такая: Создать программу для решения задачи построения слова из некоторого множества букв...

графы. поиск в ширину - C++
у меня такая задача: Определить, является ли неориентированный граф двудольным графом через алгоритм поиска в ширину. мне хотя бы...

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

Помогите написать программу поиск в ширину - C++
Здравствуйте! Необходимо написать такую программу: Входные данные - количество вершин графа и его ребра. Выход - вектор, содержащий...

Поиск в ширину - Неправильно выполняется программа - C++
ПОМОГИТЕ! ПОЧЕМУ НЕПРАВИЛЬНО ВЫПОЛНЯЕТСЯ ПРОГРАММА? #include&lt;iostream&gt; #include&lt;stdio.h&gt; #include&lt;queue&gt; using namespace...

Найти минимальный путь между двумя вершинами в неорграфе. Поиск в ширину - C++
В неориентированном графе требуется найти минимальный путь между двумя вершинами. Входные данные Первым на вход поступает число N –...

Обход в ширину - C++
Помогите написать обход в ширину на C++ без библиотек &lt;vector&gt; и т.д.

Алгоритм поиска в ширину - C++
Вот тут нашел реализацию алгоритма поиска в ширину кратчайших расстояний в графе. По идее расстояния должны храниться в массиве d, но ответ...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
mamedovvms
2916 / 837 / 93
Регистрация: 30.04.2009
Сообщений: 2,624
21.05.2010, 06:53     поиск в ширину #2
Я не настолько силен в с++ но мне кажется что скорее всего функция Graf описана в одном из файлов которые вы в самом начале прописываете.
Legendary
Сообщений: n/a
21.05.2010, 06:58     поиск в ширину #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
void Add_v_from_file()
{
printf("-----------------------------------Spisok incendentnosti-------------------\n");
int n;
int u, v, w;
freopen("input.txt", "r", stdin);
scanf("%d", &n);
Graf.resize(n+1);
while(scanf("%d%d%d", &u, &v, &w)!=EOF)
{
 Ver temp;
 temp.v = v;
 temp.w = w;
 Graf[u].push_back(temp);
 temp.v = u;
 Graf[v].push_back(temp);
}
for(int i = 1; i < Graf.size(); i++)
{
 printf("%d: ", i);
 for(int j = 0; j < Graf[i].size(); j++)
 {
  printf("(%d, %d) ", Graf[i][j].v, Graf[i][j].w);
 }
 printf("\n");
}
printf("\n");
}
Yandex
Объявления
21.05.2010, 06:58     поиск в ширину
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru