Professional Documents
Culture Documents
Check If A Given Graph Is Tree or Not - GeeksforGeeks
Check If A Given Graph Is Tree or Not - GeeksforGeeks
For an undirected graph we can either use BFS or DFS to detect above two properties.
http://www.geeksforgeeks.org/check-given-graph-tree/ 1/10
bool Graph::isTree()
7/10/2017 Check if a given graph is tree or not - GeeksforGeeks
{
return (!isCyclic_UnDirectedGraph())
already visited and u is not parent of && isInDirectedGraphStonglyConnectd();
v, then there is a cycle in graph. If we don’t find such an adjacent
}
for any vertex, we say that there is no cycle (See Detect cycle in an undirected graph for more details).
bool Graph::isInDirectedGraphStonglyConnectd()
{ How to check for connectivity?
bool* visited = new bool[V];
Since
for (intthe
i =graph
0; i is
< undirected,
V; ++i) we can start BFS or DFS from any vertex and check if all vertices are
visited[i] = false;
reachable or not. If all vertices are reachable, then graph is connected, otherwise not.
DFSUtils(visited, 0);
C++
for (int i = 0; i < V; ++i)
{ // A C++ Program to check whether a graph is tree or not
if (!visited[i])
#include<iostream>
return
#include false;
<list>
} #include <limits.h>
return
using true;
namespace std;
}
// Class for an undirected graph
class Graph
bool Graph::isCyclic_UnDirectedGraphUtils(bool* visited, int v, int parent)
{ {
int V;= true;
visited[v] // No. of vertices
list<int> *adj; // Pointer to an array for adjacency lists
bool isCyclicUtil(int v, bool visited[], int parent);
for (auto& vertex : adj[v])
public:
{ Graph(int V); // Constructor
ifvoid
(visited[vertex]
addEdge(int v,&&int
vertex
w); != //
parent)
to add an edge to graph
return true;
bool isTree(); // returns true if graph is tree
};
if (!visited[vertex])
Graph::Graph(int V)
isCyclic_UnDirectedGraphUtils(visited, vertex, v);
} {
this->V = V;
returnadj = new list<int>[V];
false;
} }
return true;
}
Graph g2(5);
g2.addEdge(1, 0);
g2.addEdge(0, 2);
g2.addEdge(2, 1);
g2.addEdge(0, 3);
g2.addEdge(3, 4);
g2.isTree()? cout << "Graph is Tree\n":
cout << "Graph is not Tree\n";
return 0;
}
Run on IDE
Java
// A Java Program to check whether a graph is tree or not
import java.io.*;
import java.util.*;
// Constructor
Graph(int v)
http://www.geeksforgeeks.org/check-given-graph-tree/ 3/10
7/10/2017 Check if a given graph is tree or not - GeeksforGeeks
Graph(int v)
{
V = v;
adj = new LinkedList[v];
for (int i=0; i<v; ++i)
adj[i] = new LinkedList();
}
return true;
}
http://www.geeksforgeeks.org/check-given-graph-tree/ 4/10
7/10/2017 Check if a given graph is tree or not - GeeksforGeeks
// Driver method
public static void main(String args[])
{
// Create a graph given in the above diagram
Graph g1 = new Graph(5);
g1.addEdge(1, 0);
g1.addEdge(0, 2);
g1.addEdge(0, 3);
g1.addEdge(3, 4);
if (g1.isTree())
System.out.println("Graph is Tree");
else
System.out.println("Graph is not Tree");
if (g2.isTree())
System.out.println("Graph is Tree");
else
System.out.println("Graph is not Tree");
}
}
// This code is contributed by Aakash Hasija
Run on IDE
Python
# Python Program to check whether
# a graph is tree or not
class Graph():
if self.isCyclicUtil(i,
http://www.geeksforgeeks.org/check-given-graph-tree/ visited, v) == True: 5/10
7/10/2017 Check if a given graph is tree or not - GeeksforGeeks
if self.isCyclicUtil(i, visited, v) == True:
return True
return False
return True
g2 = Graph(5)
g2.addEdge(1, 0)
g2.addEdge(0, 2)
g2.addEdge(2, 1)
g2.addEdge(0, 3)
g2.addEdge(3, 4)
print "Graph is a Tree" if g2.isTree() == True \
else "Graph is a not a Tree"
Output:
Graph is Tree
Graph is not Tree
▲
http://www.geeksforgeeks.org/check-given-graph-tree/ 6/10
7/10/2017 Check if a given graph is tree or not - GeeksforGeeks
Thanks to Vinit Verma for suggesting this problem and initial solution. Please write comments if you
find anything incorrect, or you want to share more information about the topic discussed above
http://www.geeksforgeeks.org/check-given-graph-tree/ 7/10
7/10/2017 Check if a given graph is tree or not - GeeksforGeeks
http://www.geeksforgeeks.org/check-given-graph-tree/ 8/10
7/10/2017 Check if a given graph is tree or not - GeeksforGeeks
Recommended Posts:
http://www.geeksforgeeks.org/check-given-graph-tree/ 9/10
7/10/2017 Check if a given graph is tree or not - GeeksforGeeks
Writing code in comment? Please use ide.geeksforgeeks.org, generate link and share the link here.
@geeksforgeeks, Some rights reserved Contact Us! About Us! Advertise with us! Privacy
Policy
http://www.geeksforgeeks.org/check-given-graph-tree/ 10/10