八皇后问题

#1:每行只有一个皇后,用数组p保存每一行皇后的列位置,p[k]表示第k行的皇后的列位置。

#2:不同行的皇后在同一列或同一斜线则冲突,与位置(a,b)冲突的位置有(a,x)(x,b),(a+x,b+x)(a+x,b-x),用一个函数判断任意两个位置是否冲突。

#3:递归函数返回时不需要恢复本次所做的修改。(编程之美上“24点游戏”就是典型的递归需要回复本次所做的修改)

#4:dfs遍历所有位置。

判断冲突可以这样:

bool no_conflict(int k,int x)       /*weather p[k]==x is proper*/
{
    for(int i=0;i<k;++i)
        if( (k-i==x-p[i])||(k-i==p[i]-x)||(x==p[i]) )
            return false;
    return true;
}






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值