dfs vs bfs code example
Example 1: depth first search
// performs a depth first search (DFS)
// nodes are number from 1 to n, inclusive
using namespace std;
vector<vector<int>> adj; // adjacency list
// visited[v] = true if v has been visited by dfs
vector<bool> visited;
bool all_edges_are_directed = true;
void dfs(int v) {
// determines if dfs has been done on v
if(visited[v])
return;
visited[v] = true;
// write code here to do stuff with node v
// traverse nodes that are adjacent to v
for (int u: adj[v]){
dfs(u);
}
}
int main() {
int n; // number of vertices
int m; // number of edges
cin >> n >> m;
adj = vector<vector<int>>(n+1, vector<int>());
visited = vector<bool>(n+1, false);
for(int i = 0; i < m; ++i) {
// nodes a and b have an edge between them
int a, b;
cin >> a >> b;
if(all_edges_are_directed)
adj[a].push_back(b);
else {
adj[a].push_back(b);
adj[b].push_back(a);
}
}
// do depth first search on all nodes
for(int i = 1; i <= n; ++i){
dfs(i);
}
}
Example 2: BFS AND DFS IN C
int n;
int adj[MAX][MAX];
int state[MAX];
void create_graph();
void BF_Traversal();
void BFS(int v);
int queue[MAX], front = -1,rear = -1;
void insert_queue(int vertex);
int delete_queue();
int isEmpty_queue();
int main()
{
create_graph();
BF_Traversal();
return 0;
}
void BF_Traversal()
{
int v;
for(v=0; v<n; v++)
state[v] = initial;
printf("Enter Start Vertex for BFS: \n");
scanf("%d", &v);
BFS(v);
}
void BFS(int v)
{
int i;
insert_queue(v);
state[v] = waiting;
while(!isEmpty_queue())
{
v = delete_queue( );
printf("%d ",v);
state[v] = visited;
for(i=0; i<n; i++)
{
if(adj[v][i] == 1 && state[i] == initial)
{
insert_queue(i);
state[i] = waiting;
}
}
}
printf("\n");
}
void insert_queue(int vertex)
{
if(rear == MAX-1)
printf("Queue Overflow\n");
else
{
if(front == -1)
front = 0;
rear = rear+1;
queue[rear] = vertex ;
}
}
int isEmpty_queue()
{
if(front == -1 || front > rear)
return 1;
else
return 0;
}
int delete_queue()
{
int delete_item;
if(front == -1 || front > rear)
{
printf("Queue Underflow\n");
exit(1);
}
delete_item = queue[front];
front = front+1;
return delete_item;
}
void create_graph()
{
int count,max_edge,origin,destin;
printf("Enter number of vertices : ");
scanf("%d",&n);
max_edge = n*(n-1);
for(count=1; count<=max_edge; count++)
{
printf("Enter edge %d( -1 -1 to quit ) : ",count);
scanf("%d %d",&origin,&destin);
if((origin == -1) && (destin == -1))
break;
if(origin>=n || destin>=n || origin<0 || destin<0)
{
printf("Invalid edge!\n");
count--;
}
else
{
adj[origin][destin] = 1;
}
}
}