n皇后问题
一、什么是n皇后问题
n-皇后问题是指将 n 个皇后放在 n∗n 的国际象棋棋盘上,使得皇后不能相互攻击到,即任意两个皇后都不能处于同一行、同一列或同一斜线上。
二、思路
即运用回溯算法,比如,n为4时,先在第一行第一列放置一个皇后,然后在第二行第三列放置一个皇后,但是到第三行时发现不能放置,这时就用递归,回溯的算法回到第二行,将第二行右移一格,再第三行,以此类推
三、代码实现
#include <stdio.h>
#include <malloc.h>
#include <math.h>
/**
* Place it there, applicable?
*/
bool place(int* paraSolution, int paraT){
int j;
for (j = 1; j < paraT; j ++){
if ((abs(paraT - j) == abs(paraSolution[j] - paraSolution[paraT])) || (paraSolution[j] == paraSolution[paraT]))
return false;
}//Of for
return true;
}//Of place
/**
* Backtracking.
*/
void backtracking(int* paraSolution, int paraN, int paraT){
int i;
if (paraT > paraN){
for (i = 1; i <= paraN; i ++)
printf("%d ", paraSolution[i]);
printf("\r\n");
}else{
for (i = 1; i <= paraN; i ++){
paraSolution[paraT] = i;
if (place(paraSolution, paraT))
backtracking(paraSolution, paraN, paraT + 1);
}//Of for i
}//Of if
}//Of backtracking
/**
* Title: n queens.<br>
*/
void nQueen(int paraN){
int i;
int* solution = (int*)malloc((paraN + 1) * sizeof(int));
for (i = 0; i <= paraN; i ++)
solution[i] = 0;
backtracking(solution, paraN, 1);
}//Of nQueen
/**
* The entrance.
*/
int main(){
nQueen(5);
return 1;
}//Of main
注解:parasolution[1]=1 表示第一行的第一列数,上述判断是否在同一对角线的方法是判断两元素横纵坐标相减的绝对值是否相等或者横纵坐标是否相同,这两种都说明元素位于对角线上