170 похожих чатов

Привет . Есть код для обхода графа в ширину


Задаю данные
1 Количество вершин 2
Количество смежных вершин для вершины 1 1
Идентификатор соседней вершины 1: 0
Количество смежных вершин для вершины 2 2
Идентификатор соседней вершины 1: 1
Идентификатор соседней вершины 2: 0
Граф
1 0
2 1 0
Поиск в ширину
Посещенная вершина 0
Показывает, что посещенная вершина только 0.
А должно быть 0, 1 , 2. Можете подсказать что не так?
#include <iostream>
#include <vector>
#include <queue>

using namespace std;

struct Vertex {
int id; // идентификатор вершины
bool visited; // флаг посещения
vector<int> adjacentVertices; // список идентификаторов смежных вершин
};

void bfs(vector<Vertex>& graph, int startVertexId) {
queue<int> vertexQueue; // очередь для посещения вершин
vertexQueue.push(startVertexId); // добавляем стартовую вершину в очередь
graph[startVertexId].visited = true; // помечаем стартовую вершину, как посещенную

while (!vertexQueue.empty()) { // пока очередь не пуста
int vertexId = vertexQueue.front(); // берем вершину из очереди
vertexQueue.pop(); // удаляем вершину из очереди
cout << "Посещенная вершина: " << vertexId << endl; // выводим идентификатор посещенной вершины

for (int adjacentVertexId : graph[vertexId].adjacentVertices) { // перебираем смежные вершины
if (!graph[adjacentVertexId].visited) { // если смежная вершина не была посещена
vertexQueue.push(adjacentVertexId); // добавляем смежную вершину в очередь
graph[adjacentVertexId].visited = true; // помечаем смежную вершину, как посещенную
}
}
}
}

int main() {
// создаем граф
setlocale(0,"Russian");
int numVertices;
cout << "Введите количество вершин: ";
cin >> numVertices;

vector<Vertex> graph(numVertices);

for(int i=0; i<numVertices; i++) {
graph[i].id = i+1;
graph[i].visited = false;
int numAdjacent;
cout << "Введите количество смежных вершин для вершины " << i+1 << ": ";
cin >> numAdjacent;

for(int j=0; j<numAdjacent; j++) {
int adjacentVertexId;
cout << "Введите идентификатор соседней вершины " << j+1 << ": ";
cin >> adjacentVertexId;
graph[i].adjacentVertices.push_back(adjacentVertexId);
}
}

// Вывод графа
cout << "Граф:" << endl;
for (Vertex vertex : graph) { // перебираем все вершины графа
cout << "Вершина " << vertex.id << " -> "; // выводим идентификатор текущей вершины в консоль
for (int adjacentVertexId : vertex.adjacentVertices) { // перебираем идентификаторы смежных вершин текущей вершины
cout << adjacentVertexId << " "; // выводим идентификаторы смежных вершин текущей вершины в консоль
}
cout << endl; // переходим на следующую строку
}

cout << endl << "Поиск в ширину:" << endl;
bfs(graph, 0); // запускаем поиск в ширину, начиная с вершины с идентификатором 0

cin.get();
return 0;
}

1 ответов

3 просмотра

Первое, что не так, это нечитаемая простыня. Код надо размещать на пастебин или годболте. Сюда давать ссылку.

Похожие вопросы

Обсуждают сегодня

А как старый хаскел с новым стыковать ? потому как тут работает https://play.haskell.org/saved/C3xpMzcd, а вот тут https://stepik.org/lesson/7602/step/9?unit=1473 нет ошибка C...
Fedor
131
А с каким компилятором не будет ошибкой использовать асм вставки?
Replicant ~
14
Вопрос я правильно понимаю что в коде newtype ArrowMap k v = ArrowMap { getArrowMap :: k -> Maybe v } getArrowMap есть функция типа k -> Maybe v, если да, то не понимаю задач...
Fedor
64
что насчет пагинга? на осдеве непонятно(
Vi Chapmann 🪙
26
Всем привет! Подскажите, как решить проблему или из-за чего это происходит. У меня есть проблема в WebStorm (v.2024.1.3): я ставлю любую тему, и через какое-то время меняется ...
Alexander Sheigov
8
Народ, кто шарит в расширенных разделах (EBR/EPR) на дисках с разметками MBR? Везде пишут (в вики рус/англ) в частности + другие источники смотрел, что первый сектор расширенн...
Eugene Krasnikov (ᴊɪɴ x)
1
Как Вы считаете нормально ли в двадцатых годах 21 века в ВУЗах Российской Федерации обучать студентов работе с TASM? Не слишком ли это "архаично"? (Если оффтоп или флейм для э...
Spiker01
52
И из-за этого сужается карман. Нет свободного полёта. Они либо могут какой-то заточенный прикладной софт, либо какой-то простой системный написать. По шаблону. А, допустим, по...
КТ315
9
Делаю велосипед логгер. К сообщению хочу прикрутить некоторую информацию, типа, кем отправлено, какой уровень, и всякое такое. И тут подумалось мне, почему бы не хранить весь...
Serjone
24
Ребят, что лучше для реверса: гидра или ида?
En Vind Av Sorg
26
Карта сайта