在8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。
算法分析:
利用回溯法在最坏的情况下,需要O(n2),而用蛮力测试所有排列需要O(n!)。
在下面的迭代算法的伪代码中,我们用c[k]=x表示第k行得到皇后放在第x列。
伪代码:
递归算法
C++代码:
void backtrack(int t)
{
if(t>num) //num为皇后的数目
{
sum++;//sum为所有的可行的解
for(int m = 1;m<num;m++)
{
cout<<x[m];//这一行用输出当递归到叶节点的时候,一个可行解
}
cout<<endl;
}
else
for(int i = 1;i<=num;i++)
{
x[t] = i;
if(place(t)) backtrack(t+1);//此处的place函数用来进行我们上面所说的条件的判断,如果成立,进入下一级递归
}
}
bool place(int k)
{
for(int j = 1;j<k;j++)
if(abs(x[k] - x[j]) == abs(k-j)||x[j] == x[k])
return false;
return true;
}