题目描述

相信大家都听过经典的“八皇后”问题吧?这个游戏要求在一个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. JMeter3.2生成图形化HTML报告

    JMeter3.0引入了Dashboard Report,用于生成HTML页面格式图形化报告的扩展模块. 该模块支持通过两种方式生成多维度图形化测试报告: 在JMeter性能测试结束时,自动生成本次测 ...

  2. PHP字符串比较,看起来值完全一样,但是就是不相等的解决方案(&zwnj;)

    1 前言 字符串比较,看起来完全一样,然后用strcmp比较,永远不相等,用var_dump查看才知道,其中一个字符多了‌看不见的特殊符号,而我长度是3. 2 样例 当你选中它,显示出来的就是人眼所见 ...

  3. ORA-00379: no free buffers available in buffer pool DEFAULT for block size 16K

    SYS@orcl> select TABLESPACE_NAME ,AUTOEXTENSIBLE from dba_data_files ; ERROR: ORA-00379: no free ...

  4. Confluence 6 为翻译显示用户界面的键(Key)名称

    这个功能在你使用 Confluence 用户界面为 Confluence 创建翻译的时候会非常有用.当你打开主面板的时候,在你访问的 URL 的最后面添加下面的文字:can add the follo ...

  5. Confluence 6 连接到 Jira 用户管理的限制

    当你在使用 JIRA 目录为用户目录的时候,请考虑下面的一些限制和建议. 不知道跨平台的多应用单点登录 当你使用 JIRA 为你的目录管理器的时候,系统将不能支持跨平台的单点登录.当 JIRA 用作目 ...

  6. day06 数字类型,字符串类型,列表类型

    一:整型int# ======================================基本使用======================================# 1.用途:记录年龄 ...

  7. Java 获取屏幕的宽、高

    import java.awt.Toolkit; public class GetScreenSize { public static void main(String[] args) { int s ...

  8. springboot拦截器HandlerInterceptor详解

    Web开发中,我们除了使用 Filter 来过滤请web求外,还可以使用Spring提供的HandlerInterceptor(拦截器). HandlerInterceptor 的功能跟过滤器类似,但 ...

  9. 跨域 XMLHttpRequest对象

    XMLHttpRequest对象是ajax编程的基础,用于发送请求(数据)与服务端进行交互. 目前主流浏览器都内置了XMLHttpRequest对象. 浏览器会使用XMLHttpRequest对象来创 ...

  10. 正则re模块

    正则表达式的特殊字符: 语法: re.match(正则语法,字符串) # re.match() 为关键字 group(1) # 取出第一个匹配 括号中的值,1位第一个括号内的值 1. 特殊字符 1 . ...