求解n皇后
要求:在国际象棋上摆放n个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法
思路:很直观的想法就是在棋盘上一个一个皇后的摆,如果冲突,则摆放在另一个位置,直至此次可以把n各皇后摆好而不产生冲突,则说明此种方法为一个解。然后将最后一个放置的皇后换个位置摆放,直至不产生冲突为止。很显然,此种思路即为算法中的回溯算法。
#include<iostream>
using namespace std;
int const N =17;
static int count=0;
int x[N];
int n;
int conflict(int k) //参数k为要放置的第k个皇后
{
int i;
for(i=1;i<k;i++)
if(abs(k-i)==abs(x[k]-x[i]) || x[k] == x[i])
return 1;
return 0;
}
int queen(int k)//参数k为要放置第k个皇后
{
if(k>n&&n>0)//k为已放置的皇后数,如果在一次递归中已放置的皇后数大于
//要放置的皇后数则说明此次递归过程为一个解
count++;
else
{
for(int t=1;t<=n;t++)
{
x[k]=t;//标明第k个皇后放在第t行
if(!conflict(k))
queen(k+1);
}
}
return count;
}
void main()
{
cout<<"请输入皇后的个数"<<endl;
cin>>n;
cout<<n<<"皇后的解个数为"<<queen(1)<<endl;
}
程序运行结果如下:
求解n皇后的更多相关文章
- 数据结构学习之栈求解n皇后问题
		
数据结构学习之栈求解n皇后问题 0x1 目的  深入掌握栈应用的算法和设计 0x2 内容  编写一个程序exp3-8.cpp求解n皇后问题. 0x3 问题描述 即在n×n的方格棋盘上,放置n个皇后 ...
 - USACO 1.5.4 Checker Challenge跳棋的挑战(回溯法求解N皇后问题+八皇后问题说明)
		
Description 检查一个如下的6 x 6的跳棋棋盘,有六个棋子被放置在棋盘上,使得每行,每列,每条对角线(包括两条主对角线的所有对角线)上都至多有一个棋子. 列号 0 1 2 3 4 5 6 ...
 - 简单遗传算法求解n皇后问题
		
版权声明:本文为博主原创文章,转载请注明出处. 先解释下什么是8皇后问题:在8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行.同一列或同一斜线上,问有多少种摆法.在不 ...
 - 回溯法求解n皇后和迷宫问题
		
回溯法是一种搜索算法,从某一起点出发按一定规则探索,当试探不符合条件时则返回上一步重新探索,直到搜索出所求的路径. 回溯法所求的解可以看做解向量(n皇后坐标组成的向量,迷宫路径点组成的向量等),所有解 ...
 - 用dfs求解八皇后问题
		
相信大家都已经很熟悉八皇后问题了,就是指:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行.同一列或同一斜线上,问有多少种摆法.主要思路:按行进行深度优先搜索,在该 ...
 - 回溯法——求解N皇后问题
		
问题描写叙述 八皇后问题是十九世纪著名数学家高斯于1850年提出的.问题是:在8*8的棋盘上摆放8个皇后.使其不能互相攻击,即随意的两个皇后不能处在允许行.同一列,或允许斜线上. 能够把八皇后问题拓展 ...
 - N皇后问题(位运算实现)
		
本文参考Matrix67的位运算相关的博文. 顺道列出Matrix67的位运算及其使用技巧 (一) (二) (三) (四),很不错的文章,非常值得一看. 主要就其中的N皇后问题,给出C++位运算实现版 ...
 - 深入N皇后问题的两个最高效算法的详解                                                    分类:            C/C++             2014-11-08 17:22    117人阅读    评论(0)    收藏
		
N皇后问题是一个经典的问题,在一个N*N的棋盘上放置N个皇后,每行一个并使其不能互相攻击(同一行.同一列.同一斜线上的皇后都会自动攻击). 一. 求解N皇后问题是算法中回溯法应用的一个经典案例 回溯算 ...
 - 多种解法解决n皇后问题
		
多种解法解决n皇后问题 0x1 目的  深入掌握栈应用的算法和设计 0x2 内容  编写一个程序exp3-8.cpp求解n皇后问题. 0x3 问题描述 即在n×n的方格棋盘上,放置n个皇后,要求每 ...
 
随机推荐
- Linux学习之CentOS(五)--CentOS下VMware-Tools安装
			
已经进入到了Linux学习之CentOS的第六篇随笔了,所以这里就介绍一下VMware-Tools的安装. VMware-Tools的安装 VMware-Tools 主要的功能就是让用户在虚拟机和真实 ...
 - SpringMVC中url-pattern /和/*的区别
			
http://blog.csdn.net/u010648555/article/details/51612030
 - Object 类
 - React Suite v3.0 正式版发布
			
React Suite v3.0 正式版发布 相信很多人会好奇,React Suite 是什么? React Suite 是 HYPERS 前端团队和 UX 团队开源的一套基于 React 的 UI ...
 - .9-浅析express源码之请求处理流程(2)
			
上节漏了几个地方没有讲. 1.process_params 2.trim_prefix 3.done 分别是动态路由,深层路由与最终回调. 这节就只讲这三个地方,案例还是express-generat ...
 - 开源Spring解决方案--lm.solution
			
Github 项目地址: https://github.com/liumeng0403/lm.solution 一.说明 1.本项目未按java项目传统命名方式命名项目名,包名 如:org.xxxx. ...
 - MySql准备工作
			
1.linux 下启动mysql 服务 sudo service mysql start 2.登录 mysql -u用户 -p密码 3.显示库 show databases: 4.使用库 use 库名 ...
 - Spring Boot消息队列应用实践
			
消息队列是大型复杂系统解耦利器.本文根据应用广泛的消息队列RabbitMQ,介绍Spring Boot应用程序中队列中间件的开发和应用. 一.RabbitMQ基础 1.RabbitMQ简介 Rabbi ...
 - C++ substr
			
函数文档:http://www.cplusplus.com/reference/string/string/substr/ /* substr(size_t pos = 0,size_t len = ...
 - k8s Kubernetes v1.10 最简易安装 shell
			
k8s Kubernetes v1.10 最简易安装 shell # Master 单节点快速安装 # 最简单的安装shell,只为快速部署k8s测试环境 #环境centos 7.4 #1 初始化环境 ...