Ir para conteúdo
Fórum Script Brasil
  • 0

Backtrack sem recursão


jotave97

Pergunta

Preciso criar um algoritmo em C para resolver o problema das N Rainhas, porém estão impostas bastantes limitações. Uma delas é não poder usar recursão. Sendo assim, preciso reformular minha função de teste:

int teste(int tab[MAX][MAX], int N, int col, int b, int c, int r, int v){

int i, j;

/* caso os testes sejam executados até que col == N, uma solução foi encontrada */

if(col == N){

    if(v == 1){

    imprimir(tab, N, b, c, r);

    }

    sol ++;

/* caso seja encontrada uma solução, as posições são computadas no mapa de frequencias */

    for(i = 0; i < N; i++){

        for(j = 0; j < N; j++){

            mapafreq[i][j] = mapafreq[i][j] + tab[i][j];

    }

}

    return 1;

}

/* realiza os testes das posições */

for(i = 0; i < N; i++){

    if(seguro(tab, N, i, col, b, c, r) == 1){

        tab[i][col] = 1;

        teste(tab, N, col + 1, b, c, r, v);

    }

/* backtrack (remove a rainha) */

    tab[i][col] = 0;

}

return 0;

}

*ignorar as variáveis b, c, r, v, elas não são interferem no problema.

Link para o comentário
Compartilhar em outros sites

1 resposta a esta questão

Posts Recomendados

Participe da discussão

Você pode postar agora e se registrar depois. Se você já tem uma conta, acesse agora para postar com sua conta.

Visitante
Responder esta pergunta...

×   Você colou conteúdo com formatação.   Remover formatação

  Apenas 75 emoticons são permitidos.

×   Seu link foi incorporado automaticamente.   Exibir como um link em vez disso

×   Seu conteúdo anterior foi restaurado.   Limpar Editor

×   Você não pode colar imagens diretamente. Carregar ou inserir imagens do URL.



  • Estatísticas dos Fóruns

    • Tópicos
      152,3k
    • Posts
      652,2k
×
×
  • Criar Novo...