N皇后问题

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 6493    Accepted Submission(s): 2951

Problem Description
在N*N的方格棋盘放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在与棋盘边框成45角的斜线上。
你的任务是,对于给定的N,求出有多少种合法的放置方法。

 
Input
共有若干行,每行一个正整数N≤10,表示棋盘和皇后的数量;如果N=0,表示结束。
 
Output
共有若干行,每行一个正整数,表示对应输入行的皇后的不同放置数量。
 
Sample Input
1
8
5
0
 
Sample Output
1
92
10
 
Author
cgf
 
Source
 
Recommend
lcy   |   We have carefully selected several similar problems for you:  2614 1258 1426 1175 1067 
 
 //31MS    256K    993 B    C++
//经典N皇后问题 深搜解法
#include<stdio.h>
#include<string.h>
int cnt,n;
int q[][];
int Judge(int x,int y)
{
for(int i=;i<n;i++) if(q[x][i] && i!=y) return ;
for(int i=;i<n;i++) if(q[i][y] && i!=x) return ;
for(int i=x+,j=y+;i<n && j<n;i++,j++)
if(q[i][j]) return ;
for(int i=x-,j=y-;i>= && j>=;i--,j--)
if(q[i][j]) return ;
for(int i=x+,j=y-;i<n && j>=;i++,j--)
if(q[i][j]) return ;
for(int i=x-,j=y+;i>= && j<n;i--,j++)
if(q[i][j]) return ;
return ;
}
void dfs(int c)
{
if(c==n){ cnt++;return;}
for(int i=;i<n;i++)
if(Judge(i,c)){
q[i][c]=;
dfs(c+);
q[i][c]=;
}
}
int main(void)
{
int a[]={};//不打表会超时
for(int i=;i<;i++){
n=i;
cnt=;
memset(q,,sizeof(q));
dfs();
a[i]=cnt;
}
while(scanf("%d",&n)!=EOF && n)
{
printf("%d\n",a[n]);
}
return ;
}

给出一个高效的位运算求法:

 //15MS    208K    704 B    G++
#include<stdio.h>
int ans[];
int sum;
int upperlim;
void dfs(int row,int ld,int rd) //某行中纵列不可取,左右对角线不可取的限制条件
{
int pos,p;
if(row!=upperlim){
pos=upperlim&(~(row|ld|rd)); //取出可以放的位置
while(pos){
p=pos&(~pos+); //取pos最左边的1
pos=pos-p; //减去可取的
dfs(row|p,(ld|p)<<,(rd|p)>>); //深搜
}
}else sum++; //搜出来后总数+1
}
int main(void)
{
for(int i=;i<;i++){
sum=;
upperlim=(<<i)-; //i个1
dfs(,,);
ans[i]=sum;
}
int n;
while(scanf("%d",&n),n)
{
printf("%d\n",ans[n]);
}
return ;
}

hdu 2553 N皇后问题 (DFS)的更多相关文章

  1. HDU 2553(N皇后)(DFS)

    http://acm.hdu.edu.cn/showproblem.php?pid=2553 i表示行,map[i]表示列,然后用DFS遍历回溯 可以参考这篇文章: http://blog.csdn. ...

  2. [HDU 2553]--N皇后问题(回溯)/N皇后问题的分析

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2553 N皇后问题 Time Limit: 2000/1000 MS (Java/Others)     ...

  3. hdu 2553 N皇后问题 (经典DFS)

    题目链接:点击链接 思路:用一维数组hang[num] = i,num表示第num行,i表示第i列,计算n = 1~10皇后的不同放置数量,然后打表 #include<stdio.h> # ...

  4. HDU 2553 N皇后问题(dfs)

    N皇后问题 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Description 在 ...

  5. hdu 2553 n皇后问题【DFS递归解法】

    <题目链接> 题目大意: Problem Description 在N*N的方格棋盘放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在与棋盘边框成45 ...

  6. HDU 2553 N皇后问题(深搜DFS)

    N皇后问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  7. hdu 2553:N皇后问题(DFS遍历,水题)

    N皇后问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  8. HDU 2553 N皇后问题【棋盘型DFS】

    N皇后问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  9. HDU 2553 N皇后问题(详细题解)

    这是一道深搜题目!问题的关键是在剪枝. 下面我们对问题进行分析: 1.一行只能放一个皇后,所以我们一旦确定此处可以放皇后,那么该行就只能放一个皇后,下面的就不要再搜了. 2.每一列只能放一个皇后,所以 ...

随机推荐

  1. Java Web入门经典扫描版

    全书共分4篇19章,其中,第一篇为“起步篇”,主要包括开启JavaWeb之门.不可不知的客户端应用技术.驾驭JavaWeb开发环境.JavaWeb开发必修课之JSP语法等内容:第二篇为“核心篇”,主要 ...

  2. Map the Debris -freecodecamp算法题目

    Map the Debris 1.要求 返回一个数组,其内容是把原数组中对应元素的平均海拔转换成其对应的轨道周期. 原数组中会包含格式化的对象内容,像这样 {name: 'name', avgAlt: ...

  3. RabbitMQ安装---rpm安装

    首先介绍一下个人的安装环境是Linux-centos7: 一.安装和配置rabbitmq的准备工作: 下载erlang:    wget http://www.rabbitmq.com/release ...

  4. hive 学习系列一(数据类型的定义)

    数字类型(Numeric Types) 整型 TINYINT(取值范围:-128 -- 127) SMALLINT(取值范围:-32,768 to 32,767) INT/INTEGER(取值范围: ...

  5. [Codeforces967C]Stairs and Elevators(二分查找)

    [不稳定的传送门] Sloution 每次试一下最近的2个楼梯或者电梯就行了 Code #include <cstdio> #include <algorithm> #incl ...

  6. Eclipse字体修改

    第一步: 第二步: 第三步: 第四步: 第五步: 第六步:

  7. Hive 压缩技术Data Compression

    Mapreducwe 执行流程 :input > map > shuffle > reduce > output 压缩执行时间,map 之后,压缩,数据存储在本地磁盘,减少磁盘 ...

  8. Spring---配置文件概述

    概述 Spring 的配置文件是用于指导 Spring 工厂进行Bean的生产.依赖关系注入及 Bean 实例分发的“图纸”,它是一个或多个标准的XML文档,J2EE 程序员必须学会并灵活应用这份“图 ...

  9. Java密码学综述---密码学基本功能

    机密性 只有发送方与指定接收方才能理解报文的内容,监听者只能截取到加密后的报文信息,但不能还原报文的内容,做到了保密 鉴别 发送方与接收方都应该能证实通信过程所涉及的另一方,通信的另一方确实具有它们所 ...

  10. CC3200模块的内存地址划分和bootloader,启动流程(二)

    1. 首先启动内部ROM固化的BOOT,然后这个ROM启动需要使用内存空间0X2000 0000 --- 0X2000 4000共16K的空间.一级BOOT的作用是串口升级和驱动库. 2. 然后是二级 ...