N皇后问题_Java递归解决N皇后问题

N皇后问题_Java递归解决N皇后问题18124 N皇后问题时间限制:2000MS 内存限制:65535K提交次数:0通过次数:0题型:编程题   语言:G++;GCC;VCDescription有N*N的国际象棋棋盘,要求在上面放N个皇后,要求任意两个皇后不会互杀,有多少种不同的放法?输入格式每一个数为T,代表CASE的数量,T<=13此后,每行一个数N(13>=N>0)

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用


  
  
  

18124 N皇后问题

时间限制:2000MS  内存限制:65535K 提交次数:0 通过次数:0

题型: 编程题   语言: G++;GCC;VC

Description

有N*N的国际象棋棋盘,要求在上面放N个皇后,要求任意两个皇后不会互杀,有多少种不同的放法?

输入格式

每一个数为T,代表CASE的数量,T<=13
此后,每行一个数N(13>=N>0)


输出格式

每一个CASE,输出对应答案


输入样例

2
4
5

输出样例

2
10



//排列问题  关键在于  while( n-- ) {  if(**) 递归 ;}  if是为了适应特殊要求的数字序列
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <iostream>
using namespace std;

void All(int T[],int n,int cur ,int &a)    //cur 代表 第cur+1 列   共n列  
{


    if(cur==n) a++;   //cur==n 说明有一个符合要求的数字序列
    else for(int i=0;i<n;i++)
    {


        int sig=1;
        for(int j=0;j<cur;j++) if(T[j]==i) {sig=0;break;} //用来限制 数字序列不在同一行
        for(int j=0;j<cur;j++) if(abs(i-T[j])==abs(cur-j)) {sig=0;break;}//第j列 不会和 第cur列 斜杀
        if(sig)//符合两个条件 才进行 下一列的 递归
        {


            T[cur]=i;
            All(T,n,cur+1,a);
        }
    }
}

int main()
{


    int n,m,T[13],Count;
    cin>>n;
    while(n--)
    {


        cin>>m;
        Count=0;//共有多少可能  初始化 0
        All(T,m,0,Count);
        cout<<Count<<endl;
    }
}



版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/187685.html原文链接:https://javaforall.net

(0)
上一篇 2026年4月18日 下午8:40
下一篇 2026年4月18日 下午8:46


相关推荐

  • SpringAOP原理分析

    SpringAOP原理分析目录 Spring 核心知识 SpringAOP 原理 AOP 编程技术什么是 AOP 编程 AOP 底层实现原理 AOP 编程使用 Spring 核心知识 Spring 是一个开源框架 Spring 是于 2003 年兴起的一个轻量级的 Java 开发框架 由 RodJohnson 在其著作 ExpertOne On OneJ2EEDevel 中阐述的部分理念和原型

    2026年3月20日
    0
  • c语言从数组中删除指定元素_c语言数组添加元素

    c语言从数组中删除指定元素_c语言数组添加元素运行结果

    2022年8月11日
    7
  • BZOJ 3747 POI2015 Kinoman 段树

    BZOJ 3747 POI2015 Kinoman 段树

    2022年1月1日
    95
  • php查看版本命令,如何查看php版本?查看php版本的详细步骤分享「建议收藏」

    php查看版本命令,如何查看php版本?查看php版本的详细步骤分享「建议收藏」如何查看php版本?查看php版本的详细步骤分享发布时间:2020-04-1509:55:44来源:亿速云阅读:413作者:小新今天小编给大家分享的是如何查看php版本?查看php版本的详细步骤,很多人都不太了解,今天小编为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。查看php版本的方法1、使用php函数phpinfo():phpinfo函数返回PHP的所有…

    2025年8月4日
    6
  • 来看看视频种子骗局[通俗易懂]

    来看看视频种子骗局1,都是很难下载的资源2,以1080BulRay命名3,文件大小集中在1G左右4,以xmous结尾(应该是作者为了好识别)5,都有官方宣传图片(Cover.jpg)和说明txt文件

    2022年4月17日
    43
  • SVD的理解

    SVD的理解近一段时间一直在看推荐系统相关的内容 看到协同过滤的时候 有的大佬将协同过滤分成了三种情况 当然实际情况也许不止三种 来考虑并做了相互之间的比较 其中有一种就是基于 SVD 的协同过滤 当时看到这个是一脸的懵 就赶紧查了一下相关的资料恶补一下 记录在这 SVD 定义 首先 我们来看一下什么是 SVD 奇异值分解 SingularValu 以下简称 SVD 是在机器学习

    2025年10月16日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号