Miguel M. Posted May 13, 2012 at 05:19 PM Report #455084 Posted May 13, 2012 at 05:19 PM Boas pessoal, estou de momento a aprender Grafos/recursividade e não consigui fazer um exercicio, vou deixar ai o que pretendia e o que fiz ate agora para me poderem ajudarem. Eu queria basicamente ver quantos numeros 1 existe, mas queria usar o metodo: Depth-First Search. #include <cstdlib>#include <vector>#include <cmath>#include <iostream>using namespace std;bool visited[6];void dfs (int node){ if (visited[node] == true) return; visited[node] = true; for (i = 0; i < 6; i ++) if (ligacoes[node][i] == 1) dfs(i);}int main(){ vector<int> id_val_vec; // guardar o ID da respectiva bola vector< pair<int,int> > ligacoes; //ligacoes entre os ID's das bolas int num,x,y,bola; // leitura for(int i=0;i<6;i++){ cin>>bola; id_val_vec.push_back(bola); cin>>x>>y; ligacoes.push_back( pair<int,int>(x,y) ); } for (int i=0;i<6;i++) visited[i] = false;system("pause"); return 0;}[/Code]
pikax Posted May 13, 2012 at 05:21 PM Report #455086 Posted May 13, 2012 at 05:21 PM nao testei mas a variavel "ligacoes" nao esta declarada na funcao dfs Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender. A beleza de um código está em decompor problemas complexos em pequenos blocos simples. "learn how to do it manually first, then use the wizzy tool to save time." "Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."
pedrosorio Posted May 13, 2012 at 05:25 PM Report #455087 Posted May 13, 2012 at 05:25 PM Não estás a chamar a função dfs em nenhum momento. Dentro da função dfs estás a usar uma notação para as "ligacoes" como se tivesses uma matriz, na realidade tens um vector de pairs, portanto claramente não podes fazer isso dessa forma. Qual é o problema que estás a resolver de facto? Contar quantas bolas têm id=1? O grafo é sempre conexo? Porquê dfs? Não respondo a dúvidas por mensagem.
Miguel M. Posted May 13, 2012 at 05:46 PM Author Report #455098 Posted May 13, 2012 at 05:46 PM O exercicio era ter as bolas e as ligaçoes entre as bolas e queria ver quantidade de bolas com o ID 1. Estava a seguir esta parte de DFS por aqui: http://i45.tinypic.com/den3ty.jpg falta esta parte: for (int i = 0; i < 7; i ++) if (ligacoes[node][i] == 1){ soma++; dfs(i);}...... for (int i=0;i<6;i++) visited[i] = false;[u][b] dfs(soma);[/b][/u][/Code] Devo ter ai muitos erros e é bem normal visto que estou a pegar em grafos com recursividade pela primeira vez 😕
pikax Posted May 13, 2012 at 05:50 PM Report #455101 Posted May 13, 2012 at 05:50 PM Não estás a chamar a função dfs em nenhum momento. Nao estas a chamar a funcao dfs na main!! Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender. A beleza de um código está em decompor problemas complexos em pequenos blocos simples. "learn how to do it manually first, then use the wizzy tool to save time." "Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now