| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 785 人关注过本帖, 1 人收藏
标题:关于n皇后问题的一个问题
取消只看楼主 加入收藏
yap
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2017-7-2
结帖率:0
收藏(1)
已结贴  问题点数:10 回复次数:0 
关于n皇后问题的一个问题

谁可以帮我解释下这个代码。好像说是递归

/*n 皇后问题*/

#include <cstdio>
#include <cmath>
#include <iostream>
using namespace std;
int n;
int queens[100];                           //用来存放算好的皇后为止。最左上角是(0,0)
void Nqueen(int k);


void Nqueen(int k)                             //在0到k-1行 皇后已经摆好的情况下,摆第k行以及其后的皇后
{
    int i;
    if(k==n)                   //如果n个皇后都摆好了
    {
        for(i=0;i<n;i++)
            cout<<queens[i]+1<<"";
        cout<<endl;
    }
   
    else
    {
        for(i=0;i<n;i++)               //逐个尝试第k个皇后的位置
        {
            int j;
            for(j=0;;j++)                              //和已经摆放好的k个皇后的位置比较,看是否冲突
            {
                if(queens[j]==i || j==k || abs(queens[j]-i) == abs(k-j) )    // 行列相同 或者 如果行相减等于列相减
                    break;                               //冲突 回溯 尝试下一个位置
            }
        
            if(j==k)
            {
                queens[k]=i;
                Nqueen(k+1);
            }
        }
    }
   
}

int main()
{
    cin>>n;
   
    Nqueen(0);                   //从第0行开始摆皇后
   
    return 0;
 }
 
 
 
搜索更多相关主题的帖子: 皇后 include int for 位置 
2017-07-14 14:07
快速回复:关于n皇后问题的一个问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.040177 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved