Leetcode 52. N-Queens II

题目

Follow up for N-Queens problem.

Now, instead outputting board configurations, return the total number of distinct solutions.

分析

只需要输出N皇后问题的解决方案的个数,只需要将上一题的代码拿来直接用即可。

int a[1000][1000];
//judge if(x,y)could be 1 in a[][]
bool place(int x,int y,int n)
{
    int i=0,j=0;
    for(i=0;i<x;i++)
        if(a[i][y]==1)  return false;
    i=x-1;j=y-1;
    while(i>=0&&j>=0)
    {
        if(a[i][j]==1)return false;
        i--;j--;
    }
    i=x-1;j=y+1;
    while(i>=0&&j<n)
    {
        if(a[i][j]==1)return false;
        i--;j++;
    }
    return true;
}
void huisu(int no,int n,int *returnSize)
{
    if(no==n-1)
    {
        for(int i=0;i<n;i++)
        {
            if(place(n-1,i,n)==true)
            {
                a[n-1][i]=1;
                *returnSize=*returnSize+1;
                a[n-1][i]=0;
            }
        }
    }
    else
    {
        for(int i=0;i<n;i++)
        {
            if(place(no,i,n)==true)
            {
                a[no][i]=1;
                huisu(no+1,n,returnSize);
                a[no][i]=0;
            }
        }
    }
}


int totalNQueens(int n) {
    if(n==0)return 1;
    int returnSize=0;
    for(int i=0;i<n;i++)
    {
        for(int j=0;j<n;j++)
            a[i][j]=0;
    }
    huisu(0,n,&returnSize);
    return returnSize;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原题 根据n皇后问题,现在返回n皇后不同的解决方案的数量而不是具体的放置布局。 样例比如n=4,存在2种解决方案 ...
    Jason_Yuan阅读 395评论 0 0
  • 回溯法,非递归求 N 皇后问题解个数,Python 3 实现: 源代码已上传 Github,持续更新。 源代码已上...
    Zentopia阅读 217评论 0 0
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,779评论 0 33
  • 今天算下日子 虽然是六月底毕业的 但实际工作好像是快一年了 大概也就是在去年的三月份放弃了调剂毅然决然地去了北京...
    Hannah_2217阅读 142评论 0 0
  • 这是一个我思考了很久的问题,很难回答。难在这是一个剖析自己,拷问价值观的问题。有些对话可以违心,可以闪烁,但回答这...
    喵小东阅读 377评论 0 1