首页 > 其他 > 详细

HDU-2553-N皇后问题

时间:2014-04-14 03:52:09      阅读:486      评论:0      收藏:0      [点我收藏+]

题目链接:

http://acm.hdu.edu.cn/showproblem.php?pid=2553

此题是深搜入门题,套用模板就可以,注意打表,避免TLE。

代码如下:

#include<iostream>
#include<cstring>
#include<math.h>
#include<cstdio>
#include<cstdlib>
using namespace std;
int vis[11][11];
int a[11];
int sum,n;
bool check(int x) //检查此位置能否放置
{
    int i;
    int flag=1;
    for(i=0;i<x;i++)
    {
        if(a[i]==a[x]||abs(i-x)==abs(a[i]-a[x]))
        {
                flag=0;
                break;
        }
    }
    if(flag)return true;
    else return false;
}

void dfs(int cur)
{
    int i;
    if(cur==n)
    {
        sum++;
        return ;
    }
    for(i=0;i<n;i++)
    {
        a[cur]=i;
        if(check(cur)&&!vis[cur][i])
        {
            vis[cur][i]=1;
            dfs(cur+1);
            vis[cur][i]=0;
        }
    }
    return ;
}
int main()
{
    int h[11];
    for(n=0;n<11;n++)//若不打表,此题会超时
    {
        sum=0;
        memset(vis,0,sizeof(vis));
        dfs(0);
        h[n]=sum;
    }
    while(scanf("%d",&n),n)
    {
        printf("%d\n",h[n]);
    }
    return 0;
}


HDU-2553-N皇后问题,布布扣,bubuko.com

HDU-2553-N皇后问题

原文:http://blog.csdn.net/pwaiyuan/article/details/23613805

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!