Ниже приведен код, который я написал.Реализация графа и BFS в C++ с использованием STL
#include <iostream>
#include <vector>
#include <list>
#include <queue>
using namespace std;
const int V=5;
vector<list<int> > a(V);
int BFS(int s)
{
int visited[V]={0};
queue<int> Q;
visited[s]=1;
Q.push(s);
while(!Q.empty())
{
int x=Q.front();
vector<list<int> >::iterator it1=a.begin()+x;
list<int> it2=*it1;
list<int>::iterator iter=it2.begin();
while(iter!=it2.end())
{
if(visited[*iter]==0)
{
visited[*iter]=1;
Q.push(*iter);
}
visited[x]=2;
Q.pop();
iter++;
}
}
return 0;
}
void addEdge(int i, int j)
{
a[i].push_back(j);
a[j].push_back(i);
}
int main() {
vector<list<int> >::iterator it1=a.begin();
addEdge(0,1);
addEdge(0,2);
addEdge(2,1);
while(it1!=a.end())
{
list<int> it2=*it1;
list<int>::iterator iter=it2.begin();
while(iter!=it2.end())
{
cout<<*iter<<" ";
iter++;
}
cout<<endl;
it1++;
}
cout<<BFS(0);
return 0;
}
Компилятор дает мне ошибку времени выполнения при выполнении BFS (0). Поскольку у меня нет большого опыта работы с итераторами, я думаю, что ошибка исходит из операторов итератора в функции BFS. Пожалуйста, помогите мне решить проблемы в моем коде.
Спасибо!
Компилятор не может (по определению) дать вам ошибку времени выполнения - вы пробовали отлаживать свою программу? – MikeMB
@MikeMB: Извините, я должен был быть более конкретным. По компилятору я имел в виду, что я использую онлайн-компилятор CodeChef. –