Given u and v vertices, I want to check if no circuit passes through the edge (u,v) in a directed graph implemented with adjacency list.
here s a brief description of my class :
template <class T>
class Digraph
{
public:
Digraph();
~Digraph();
bool acyclic(T u, T v) const;
int nb_sommets() const;
private:
std::map<T, std::set<T>> graph;
}
What I tried :
template <class T>
bool Digraph<T>::acyclic(T u, T v) const
{
// Base case
if (u == v)
return true;
// Mark all the vertices as not visited
bool *visited = new bool[nb_sommets()];
for (int i = 0; i < nb_sommets(); i++)
visited[i] = false;
std::list<int> queue;
visited[u] = true;
queue.push_back(u);
std::list<int>::iterator i;
while (!queue.empty())
{开发者_运维技巧
u = queue.front();
queue.pop_front();
for (i = graph.at(u).begin(); i != graph.at(u).end(); ++i)
{
if (*i == v)
return true;
if (!visited[*i])
{
visited[*i] = true;
queue.push_back(*i);
}
}
}
return false;
}
I have done research to implement the algorithm, however I still get errors. Will someone be kind to help me find the error in my implementation, or can direct me to a solution. thank you !!
精彩评论