Backtracking : N-Queen problem ?
Hello,
(En espérant y voir plus clair)
Ce code déniché sur Youtube, (modifié sensiblement) permet d'obtenir les solutions du problème des N reines.
https://www.youtube.com/watch?v=p4_QnaTIxkQ
Ce qui me met dans le trouble, c'est au moment du "backtracking" de la fonction nQueens, la boucle for(int colonne = 1 ; colonne<=n ;colonne++), qui dit bien tant que c'est inférieur ou égal à n, soit 4 pour cet exemple.
Hors, après avoir vérifié si la ligne 3 et la colonne 4 est une place valide (et qui ne l'est pas), la colonne incrémente à 5 ? Les positions occupées par les reines, à ce moment là, sont ligne 1, colonne 1 et ligne 2, colonne 3.
Alors, je ne comprends pas pourquoi après l'incrémentation, la fonction reboucle à partir de la ligne 2, colonne 4 ?
En gros, de if(place (3,4), qui retourne false, il passe à if(place (2,4))
(Sur papier c'est facile à exprimer, mais en codant, c'est une autre affaire).
Merci d'avance.
Code:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
|
#include <iostream>
#include <cstdlib>
using namespace std;
int solution = 0;
int x[10];
void nQueens(int);
bool place(int , int);
int n = 4;
int main() {
nQueens(1);
return 0;
}
void nQueens(int ligne){
for(int colonne = 1 ; colonne<=n ;colonne++){
if(place(ligne,colonne)){
x[ligne] = colonne;
if (ligne==n)
{
solution ++;
for (int a=1; a<=n; a++)
cout<< x[a] << " ";
cout << endl << "Solution : " << solution << endl;
}else
{
nQueens(ligne+1);
}
}
}
}
bool place(int ligne , int colonne){
for(int j = 1 ; j<=(ligne-1);j++){
if((x[j] == colonne)||(abs(x[j]-colonne)== abs(j-ligne)))
{
return false;
}
}
return true;
} |