题目描述

相信大家都听过经典的“八皇后”问题吧?这个游戏要求在一个8×8的棋盘上放置8个皇后,使8个皇后互相不攻击(攻击的含义是有两个皇后在同一行或同一列或同一对角线上)。

桐桐对这个游戏很感兴趣,也很快解决了这个问题。可是,他想为自己增加一点难度,于是他想求出n皇后的解的情况。

你能帮助她吗?

输入输出格式

输入格式:

一行,仅有一个数n(1≤n≤14),表示为n皇后问题。

输出格式:

输出仅有一个数,表示n皇后时问题的解法总数。

输入输出样例

输入样例:

8
输出样例:

92
思路:
从第一行开始放置每一个皇后,并标记所在的列和对角线。

初始代码:
//程序名:新的C++程序
//作者: #include<iostream>
#include<fstream>
#include<algorithm> using namespace std;
int n,b[],c[],d[],t;
void ch(int j,int i,int s)
{
b[i]=j;
c[i+s]=j;
d[i-s+n-]=j;
}
void dfs(int s)
{
if(s==n+){t++;return;}
for(int i=;i<=n;i++)
{
if(!b[i]&&!c[i+s]&&!d[i-s+n-])
{
ch(,i,s);
dfs(s+);
ch(,i,s);
}
}
}
int main()
{
cin>>n;
dfs();
cout<<t; return ;
}

代码


发现当n=14时,用时超过1秒。
可以利用放置方法的对称性解决问题。
解决方案: 1.当n为偶数时,第一个皇后只放在左侧,最后再把结果乘2.
//程序名:新的C++程序
//作者: #include<iostream>
#include<fstream>
#include<algorithm>
#include<ctime> using namespace std;
int n,a[],b[],c[],d[],t,m;
void dfs(int s)
{
if(s==n+){t++;return;}
if(n%==)
if(s==)
for(int i=;i<=m;i++)
{
if(!b[i]&&!c[i+s]&&!d[i-s+n-])
{
a[s]=i;
b[i]=;
c[i+s]=;
d[i-s+n-]=;
dfs(s+);
b[i]=;
c[i+s]=;
d[i-s+n-]=;
}
}
else
for(int i=;i<=n;i++)
{
if(!b[i]&&!c[i+s]&&!d[i-s+n-])
{
a[s]=i;
b[i]=;
c[i+s]=;
d[i-s+n-]=;
dfs(s+);
b[i]=;
c[i+s]=;
d[i-s+n-]=;
}
}
else
for(int i=;i<=n;i++)
{
if(!b[i]&&!c[i+s]&&!d[i-s+n-])
{
a[s]=i;
b[i]=;
c[i+s]=;
d[i-s+n-]=;
dfs(s+);
b[i]=;
c[i+s]=;
d[i-s+n-]=;
}
}
}
int main()
{
cin>>n;
m=n/;
dfs();
if(n%==)cout<<t;
else cout<<t*; return ;
}

代码

2.当n为偶数时,第一个皇后只放在左侧,反之第一个皇后放在左侧及中线,第二个放在其左边。最后再把结果乘2.
 //程序名:新的C++程序
//作者: #include<iostream>
#include<fstream>
#include<algorithm>
#include<ctime> using namespace std;
int n,a[],b[],c[],d[],t;
void dfs(int s,int k)
{
if(s==n+){t++;return;}
for(int i=;i<=k;i++)
{
if(!b[i]&&!c[i+s]&&!d[i-s+n-])
{
a[s]=i;
b[i]=;
c[i+s]=;
d[i-s+n-]=;
if(n%==&&a[]==(n+)/&&s==)dfs(,(n+)/-);
else dfs(s+,n);
b[i]=;
c[i+s]=;
d[i-s+n-]=;
}
}
}
int main()
{
cin>>n;
dfs(,(n+)/);
cout<<t*; return ;
}

代码

桐桐的数学游戏(N皇后)的更多相关文章

  1. Java实现桐桐的数学难题

    桐桐的数学难题 题目描述 今天数学课上,桐桐学习了质数的知识:一个正整数如果只能被1和它本身整除,那么这个整数便是质数.桐桐就想:任意一个正整数是否都能分解成若干个质数相乘的形式呢?输入一个正整数n( ...

  2. 桐桐的贸易--WA

    问题 A: 桐桐的贸易 时间限制: 1 Sec  内存限制: 64 MB提交: 15  解决: 2[提交][状态][讨论版] 题目描述 桐桐家在Allianceance城,好友ROBIN家在Horde ...

  3. Vijos P1325桐桐的糖果计划

    > P1325桐桐的糖果计划 标签:**图结构 强连通分量** 描述 桐桐很喜欢吃棒棒糖.他家处在一大堆糖果店的附近. 但是,他们家的区域经常出现塞车.塞人等情况,这导致他不得不等到塞的车或人走 ...

  4. vijos1325 桐桐的糖果计划

    Description 桐桐是一个快乐的小朋友,他生活中有许多许多好玩的事,让我们一起来看看吧-- 桐桐很喜欢吃棒棒糖.他家处在一大堆糖果店的附近. 但是,他们家的区域经常出现塞车.塞人等情况,这导致 ...

  5. 桐桐的糖果计划(vijos 1325)

    背景 桐桐是一个快乐的小朋友,他生活中有许多许多好玩的事,让我们一起来看看吧…… 描述 桐桐很喜欢吃棒棒糖.他家处在一大堆糖果店的附近. 但是,他们家的区域经常出现塞车.塞人等情况,这导致他不得不等到 ...

  6. 【2018寒假集训 Day1】【位运算】桐桐的运输方案

    桐桐的运输方案(transp) [问题描述] 桐桐有 N 件货物需要运送到目的地,它们的重量和价值分别记为: 重量:W1,W2,…,Wn: 价值:V1,V2,…,Vn: 已知某辆货车的最大载货量为 X ...

  7. VIJOS-P1325 桐桐的糖果计划

    VIJOS-P1325 桐桐的糖果计划 JDOJ 1432 桐桐的糖果计划 https://neooj.com/oldoj/problem.php?id=1432 Description 桐桐很喜欢吃 ...

  8. 20180606模拟赛T4——数学游戏

    数学游戏 题目描述: 小T又发脑残了,没错,她又要求奇怪的东西,这次她想知道[X,Y]之间整数有多少可以表示成K个不同的B的幂的和形势.如\(x,y,k,b=15,20,2,2\),则有: \[17= ...

  9. Vijos P1325桐桐的糖果计划(有向图双连通分量)

    /*重边不能删 不能删 不能删...*/ #include<iostream> #include<cstdio> #include<cstring> #define ...

随机推荐

  1. servlet web.xml配置选项详解

    一般的web工程中都会用到web.xml,web.xml主要包括一些配置标签,例如Filter.Listener.Servlet等,可以用来预设容器的配置,可以方便的开发web工程.但是web.xml ...

  2. js-DOM事件

    var EventUtil = { addHandler:function(elm,type,handler){//添加事件 if(elm.addEventListener){ elm.addEven ...

  3. Windows下安装Confluence并破解汉化

    注:本文来源于<Windows下安装Confluence并破解汉化> 一.事前准备 1:JDK下载并安装:jdk-6u45-windows-i586.exe 2:MySQL JDBC连接驱 ...

  4. Confluence 6 禁用或者重新启用一个任务

    在默认的情况下,所有的 Confluence 计划任务都是默认启用的. 使用 启用(Disable )/ 禁用(Enable )连接操作来启用和禁用每一个计划任务. 不是所有的加护任务都可以被禁用的. ...

  5. Confluence 6 WebDAV 禁用严格路径检查

    如果你在你的 WebDAV 客户端发现了一些不正常的现象,例如文件夹在 Confluence 中是存在的,但是在你客户端下载的文件中就不存在了.你可以禁用  WebDAV 插件中的严格路径检查选项,这 ...

  6. 《剑指offer》旋转数组中的最小数字

    本题来自<剑指offer> 旋转数组中的最小数字 题目: 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素. 例 ...

  7. eclipse maven .jar中没有主清单属性

    报错环境: windows系统eclipse maven 打包jar包后, 运行 java -jar 报错 E:\My_java\mysql\target>java -jar original- ...

  8. bzoj 2427

    非常好的一道题,可以说是树形dp的一道基础题 首先不难发现,:如果我们把有关系的两个点用有向边相连,那么就会形成一个接近树的结构.如果这是一棵完美的树,我们就可以直接在树上打背包了 但是这并不是一棵完 ...

  9. 性能测试四十九:ngrinder压测平台

    下载地址:https://sourceforge.net/projects/ngrinder/files/ ngrinder工作原理:这里的controller就是ngrinder平台 部署(以win ...

  10. 用ffmpeg把视频编码格式转为h.264

    command: ffmpeg -i infile.mp4 -an -vcodec libx264 -crf 23 outfile.h264