Deep First Search
Publicado por Jose Maria Silveira Neto 31/03/2004
[ Hits: 11.738 ]
O algoritmo mais simples para solucionar problemas com grafos.
Ele percorre todo vertice adjacente que ainda não foi visitado (ou que já foi visitado com um custo mais alto).
Ele serve para resolver problemas como labirintos, distancia mais curta entre duas cidades, etc. Porém não é o algoritmos mais eficiênte.
Implementação recursiva.
/* Grafo+DeepFirstSearch
* Preparacao para a OBI 2004
* Jose Maria Silveira Neto
* */
#include<stdio.h>
#define max 50
#define nulo 0
#define infinito max-1
enum booleano {false,true};
int grafo[max][max];
int distancia[max];
int vertices, arestas;
int custo=0;
// ********** GRAFO
void limpa_grafo(){
int i,j;
for (i=0;i<vertices;i++)
for (j=0;j<vertices;j++) grafo[i][j]=nulo;
}
void mostra_grafo(){
int i,j;
for (i=0;i<vertices;i++){
for (j=0;j<vertices;j++){
if (grafo[i][j]==nulo)printf(". ");
else printf("* ");
}
printf("\n");
}
}
void ler_grafo(){
int i,j,a,b;
scanf("%d %d",&vertices, &arestas);
for (j=0;j<arestas;j++){
scanf("%d %d",&a,&b);
grafo[a-1][b-1]=1;
grafo[b-1][a-1]=1; // (1)
}
}
int grau(int n){
int i,ocorrencias;
for (i=0;i<vertices;i++)
if (grafo[n][i]) ocorrencias++;
return(ocorrencias);
}
// Visita DFS
void visitaDFS(int n){
int i;
distancia[n]=custo;
for (i=0;i<vertices;i++)
if ( (grafo[n][i]) && (custo<distancia[i]) ){
custo++;
printf("visitando %d a partir de %d. custo= %d \n",i,n,custo);
visitaDFS(i);
custo--;
}
}
// Deep First Search (Busca em profundidade)
void DFS(int source){
int i;
printf("Inicializando uma DFS em %d\n",source);
for(i=0;i<vertices;i++){distancia[i]=infinito;}
distancia[source]=0;
custo=0;
for(i=0;i<vertices;i++)
if ( (grafo[source][i]) && (custo<distancia[i])){
printf("visitando %d a partir de %d . custo= %d \n",i,source,custo);
custo++;
visitaDFS(i);
custo--;
}
}
// ********** PRINCIPAL
int main(){
int i;
limpa_grafo();
ler_grafo();
mostra_grafo();
DFS(0);
for (i=0;i<vertices;i++){printf("[%d]",distancia[i]);}
printf("\n");
}
// (1): Admite-se que o grafo eh bidirecional, nao ponderado e que os vertices
// sao numerados a partir de 1. Este codigo pode ser facilmente alterado
// para qualquer outro tipo de grafo.
Lista duplamente encadeada com cabecalho
Nenhum comentário foi encontrado.
IA Turbina o Desktop Linux enquanto distros renovam forças
Como extrair chaves TOTP 2FA a partir de QRCODE (Google Authenticator)
Linux em 2025: Segurança prática para o usuário
Desktop Linux em alta: novos apps, distros e privacidade marcam o sábado
IA chega ao desktop e impulsiona produtividade no mundo Linux
Como instalar o repositório do DBeaver no Ubuntu
Como instalar o Plex Media Server no Ubuntu
Digitando underscore com "shift" + "barra de espaços"
Como ativar a lixeira e recuperar aquivos deletados em um servidor Linux
Como mudar o nome de dispositivos Bluetooth via linha de comando
Como posso remover arquivos MSG duplicados das minhas pastas de forma ... (0)
Assinador JNLP do Site Portal da Nota Fiscal Eletrônica (4)









