题目描述

相信大家都听过经典的“八皇后”问题吧?这个游戏要求在一个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. Linux虚拟串口

    将下列Python代码保存成VitrualCom.py: Code#! /usr/bin/env python #coding=utf-8 import pty import os import se ...

  2. ACM-ICPC 2018 焦作赛区网络预赛 I Save the Room

    Bob is a sorcerer. He lives in a cuboid room which has a length of AAA, a width of BBB and a height ...

  3. ant 相关命令

    # jmeter-ant A Simple Ant project for JMeter Performance Test # Pre-Requisite* Java 1.7 or above* JM ...

  4. Confluence 6 MySQL 测试你的数据库连接

    在你的数据库设置界面,有一个 测试连接(Test connection)按钮可以检查: Confluence 可以连接你的数据库服务器 数据库字符集,隔离级别和存储引擎是正确的 你的数据库用户有正确的 ...

  5. 纯css使用线性渐变实现滚动进度条(来自于微信前端早读课)

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. jQuery为div添加select和option

    简单描述:用jQuery给页面添加select下拉框,直接上图 总结:清楚明了^_^

  7. Python GUI界面编程

    常用GUI框架 wxPython 安装wxPython pip install -U wxPython C:\Users> pip install -U wxPython Collecting ...

  8. easyui组件window拖动时超过浏览器顶部则无法拖回

    项目研发过程中遇到一个问题,easyui的window可以随意拖动或者放大缩小,但是鼠标只有放在“header”上面时鼠标箭头才会变成四个方向的箭头,也就是只有在这时才能拖动窗口:但是当拖动的窗口超过 ...

  9. HTML5 CSS3 Transform 笔记 (scale不起作用)

    Transform的 scale属性不能作用于 inline元素上,例如span 并且动画 animation  也不能作用于inline元素上 可以给span加display:inline-bloc ...

  10. python中深拷贝与浅拷贝

    # 1.浅拷贝(复制东西)a = [11,22,33] # 实际上是浅拷贝# 没有把这个变量的值赋进去,而是把另一个变量的地址拿过去了,就叫浅拷贝.b = a # print(id(a))# prin ...