Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/lfeq/dfs

Non-Recursive Depth-First Search (DFS) in C++
https://github.com/lfeq/dfs

Last synced: about 1 month ago
JSON representation

Non-Recursive Depth-First Search (DFS) in C++

Awesome Lists containing this project

README

        

# Búsqueda en Profundidad No Recursiva (DFS) en C++
## Introducción

En teoría de grafos, la Búsqueda en Profundidad (DFS, por sus siglas en inglés) es un algoritmo utilizado para recorrer un grafo. Comienza en un vértice dado y explora todos sus vértices adyacentes, luego todos los vértices adyacentes de esos vértices, y así sucesivamente. Este proceso se repite hasta que se hayan visitado todos los vértices en el grafo.

DFS se puede implementar de forma recursiva o no recursiva. En este artículo, discutiremos la implementación no recursiva de DFS en C++.

## Explicación del Código

El código para el algoritmo DFS no recursivo se muestra a continuación:

```cpp
#include
#include
#include

using namespace std;

class Graph {
private:
int n; // Number of vertices
vector> adjacency_list; // Adjacency list

public:
Graph(int n) : n(n), adjacency_list(n) {}

// Add an edge from u to v
void add_edge(int u, int v) {
adjacency_list[u].push_back(v);
}

// Implement the non-recursive DFS algorithm
void dfs_non_recursive(int s) {
vector visited(n, false); // Create a vector to mark visited vertices
stack stack; // Create a stack
stack.push(s); // Put the initial vertex into the stack
while (!stack.empty()) { // While the stack is not empty
int u = stack.top();
stack.pop();
if (!visited[u]) { // If the vertex has not been visited
visited[u] = true; // Mark it as visited
cout << u << " "; // Print the vertex
for (int v : adjacency_list[u]) { // Traverse vertices adjacent to u
stack.push(v); // Put them into the stack
}
}
}
}
};

int main() {
Graph g(6);
g.add_edge(0, 1);
g.add_edge(0, 2);
g.add_edge(0, 3);
g.add_edge(1, 3);
g.
}
```

## Pasos para Ejecutar

Compile el código C++ utilizando su compilador preferido. Puede usar el siguiente comando en la línea de comandos si tiene g++ instalado:
```bash
g++ main.cpp Demonstrations.cpp -o nombre_del_ejecutable
```

Ejecute el programa compilado:
```bash
nombre_del_ejecutable
```

Ejecutar en Replit
https://replit.com/@LorenzEquihua/DFS#main.cpp

# Non-Recursive Depth-First Search (DFS) in C++
## Introduction

In graph theory, Depth-First Search (DFS) is an algorithm used to traverse a graph. It starts at a given vertex and explores all its adjacent vertices, then all the adjacent vertices of those vertices, and so on. This process continues until all vertices in the graph have been visited.

DFS can be implemented recursively or non-recursively. In this article, we will discuss the non-recursive implementation of DFS in C++.

## Code Explanation

The code for the non-recursive DFS algorithm is shown below:

```cpp
#include
#include
#include

using namespace std;

class Graph {
private:
int n; // Number of vertices
vector> adjacency_list; // Adjacency list

public:
Graph(int n) : n(n), adjacency_list(n) {}

// Add an edge from u to v
void add_edge(int u, int v) {
adjacency_list[u].push_back(v);
}

// Implement the non-recursive DFS algorithm
void dfs_non_recursive(int s) {
vector visited(n, false); // Create a vector to mark visited vertices
stack stack; // Create a stack
stack.push(s); // Put the initial vertex into the stack
while (!stack.empty()) { // While the stack is not empty
int u = stack.top();
stack.pop();
if (!visited[u]) { // If the vertex has not been visited
visited[u] = true; // Mark it as visited
cout << u << " "; // Print the vertex
for (int v : adjacency_list[u]) { // Traverse vertices adjacent to u
stack.push(v); // Put them into the stack
}
}
}
}
};

int main() {
Graph g(6);
g.add_edge(0, 1);
g.add_edge(0, 2);
g.add_edge(0, 3);
g.add_edge(1, 3);
// Add more edges here if needed
g.dfs_non_recursive(0); // Start DFS from vertex 0
return 0;
}
```

## Execution Steps
Compile the C++ code using your preferred compiler. You can use the following command in the command line if you have g++ installed:

```bash
g++ main.cpp Demonstrations.cpp -o executable_name
```

Run the compiled program:

```bash
executable_name
```

Run on Replit https://replit.com/@LorenzEquihua/DFS#main.cpp