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

N皇后问题

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 8077    Accepted Submission(s): 3603



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
 这个问题最终理解啦!还记得第一次接触这个问题时一直在逃避,认为感觉起来好麻烦,不想去思考,在昨天经过队友不厌其烦特别耐心的给我解说了这个问题的思路以及解决方法之后感觉豁然开朗啊!
这个问题应用了深搜,回溯的思想。第一个是非常好放的,后面的就得慢慢来的,后面若碰到了不能放的就调整上一层,直到所有搜完。*-*
以下是我理解这个问题的代码,仅用于理解:
#include<iostream>
#include<string.h>
int tot,c[20],n; void search(int cur)//cur控制行
{
int i,j;
if(cur==n)
tot++;
else
for(i=0;i<n;i++)
{
int ok=1;
c[cur]=i;//i控制列;
for(j=0;j<cur;j++)
if(c[cur]==c[j]||cur-c[cur]==j-c[j]||cur+c[cur]==j+c[j])//推断行列,左右对角是否符合条件;
{
ok=0;
break;
}//不合格跳出到i++。
if(ok)
search(cur+1);
}
}
int main()
{
while(scanf("%d",&n)!=EOF)
{
if(n==0)break;
tot=0;
search(0);//从0行開始搜索。
printf("%d\n",tot);
}
return 0;
}

这个代码提交的时候时间不合格。要打表。。。

AC代码例如以下:
#include<iostream>
#include<cstring>
using namespace std;
int vis[20][20],w[12];
int n,tot;
void dfs(int x){
int i;
if(x == n) tot++;
else{
for(i=0;i<n;i++){
if(!vis[0][i] && !vis[1][x+i] && !vis[2][x-i+n])//不同行列对角。
{
vis[0][i]=vis[1][x+i]=vis[2][x-i+n]=1;//改动全局变量。
dfs(x+1);
vis[0][i]=vis[1][x+i]=vis[2][x-i+n]=0;//改回来。
}
}
}
}
int main(){
int j,a;
for(j=1;j<=10;j++)//打表,控制在1到10。
{
tot=0;
memset(vis,0,sizeof(vis));
n=j;
dfs(0);
w[j]=tot;
}
while(scanf("%d",&a) && a)
{
printf("%d\n",w[a]);
}
return 0;
}

杭电 2553 N皇后问题的更多相关文章

  1. 杭电 2553 N皇后问题 (dfs)

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

  2. 杭电ACM题单

    杭电acm题目分类版本1 1002 简单的大数 1003 DP经典问题,最大连续子段和 1004 简单题 1005 找规律(循环点) 1006 感觉有点BT的题,我到现在还没过 1007 经典问题,最 ...

  3. 杭电acm习题分类

    专注于C语言编程 C Programming Practice Problems (Programming Challenges) 杭电ACM题目分类 基础题:1000.1001.1004.1005. ...

  4. acm入门 杭电1001题 有关溢出的考虑

    最近在尝试做acm试题,刚刚是1001题就把我困住了,这是题目: Problem Description In this problem, your task is to calculate SUM( ...

  5. 杭电acm 1002 大数模板(一)

    从杭电第一题开始A,发现做到1002就不会了,经过几天时间终于A出来了,顺便整理了一下关于大数的东西 其实这是刘汝佳老师在<算法竞赛 经典入门 第二版> 中所讲的模板,代码原封不动写上的, ...

  6. 杭电OJ——1198 Farm Irrigation (并查集)

    畅通工程 Problem Description 某省调查城镇交通状况,得到现有城镇道路统计表,表中列出了每条道路直接连通的城镇.省政府"畅通工程"的目标是使全省任何两个城镇间都可 ...

  7. 杭电ACM分类

    杭电ACM分类: 1001 整数求和 水题1002 C语言实验题——两个数比较 水题1003 1.2.3.4.5... 简单题1004 渊子赛马 排序+贪心的方法归并1005 Hero In Maze ...

  8. 高手看了,感觉惨不忍睹——关于“【ACM】杭电ACM题一直WA求高手看看代码”

    按 被中科大软件学院二年级研究生 HCOONa 骂为“误人子弟”之后(见:<中科大的那位,敢更不要脸点么?> ),继续“误人子弟”. 问题: 题目:(感谢 王爱学志 网友对题目给出的翻译) ...

  9. C#利用POST实现杭电oj的AC自动机器人,AC率高达50%~~

    暑假集训虽然很快乐,偶尔也会比较枯燥,,这个时候就需要自娱自乐... 然后看hdu的排行榜发现,除了一些是虚拟测评机的账号以外,有几个都是AC自动机器人 然后发现有一位作者是用网页填表然后按钮模拟,, ...

随机推荐

  1. 标准C程序设计七---74

    Linux应用             编程深入            语言编程 标准C程序设计七---经典C11程序设计    以下内容为阅读:    <标准C程序设计>(第7版) 作者 ...

  2. 无密码登录Linux

    配置主机A无密码登录主机B 主机A:192.168.1.110 主机B:192.168.1.111 先确保所有主机的防火墙处于关闭状态. 在主机A上执行如下: 1. $cd ~/.ssh 2. $ss ...

  3. sql server2008 R2安装总结

    1,卸载注意 在卸载Microsoft SQL Server 2008 R2 安装程序(简体中文) 出现 :“警告 26003.无法卸载 Microsoft SQL Server 2008 R2 安装 ...

  4. Struts+ibatis-学习总结一

    1查询并返回list 别名映射->实体类:resultClass <select id=" selectAll" resultClass="AppLog&qu ...

  5. AC日记——合唱队形 洛谷 P1901

    题目描述 N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2, ...

  6. BZOJ 4540 [Hnoi2016]序列 (单调栈 + ST表 + 莫队算法)

    题目链接  BZOJ4540 考虑莫队算法. 这题难在$[l, r]$到$[l, r+1]$的转移. 根据莫队算法的原理,这个时候答案应该加上 $cal(l, r+1) + cal(l+1, r+1) ...

  7. Maven的构建/测试/打包

    继上一篇http://www.cnblogs.com/EasonJim/p/6809882.html使用Maven创建工程后,接下来是使用Maven进行构建/测试/打包. 在打包之前,先熟悉一下Mav ...

  8. 邁向IT專家成功之路的三十則鐵律 鐵律三:IT人長久之道–站對邊

    這一回來談談IT人對於技術的學習.對於一位專業的IT人來說,在自己有興趣的技術領域之中,究竟要如何來正確選擇學習的方向呢?關於這個問題的答案,筆者個人深深體會到這確實會成為一位專業IT人士的長久經營之 ...

  9. android权限大全转http://www.cnblogs.com/classic/archive/2011/06/20/2085055.html

    android权限大全转http://www.cnblogs.com/classic/archive/2011/06/20/2085055.html 访问登记属性 android.permission ...

  10. Projective Texture的原理与实现 【转】

              Projective Texture是比较常见的一种技术,实现起来代码也就区区的不过百行,了解其原理及技术细节是我们的重点,知其然,知其所以然.        粗略的说就是想象场景 ...