N皇后问题 回溯非递归算法 C++实现2
运行结果

代码如下
#include <bits/stdc++.h>
using namespace std;
const int MAX = ;
const char *LINE32 = "--------------------------------";
const bool PRINT_DETAILS = false;
long long n, cnt = ;// n表示皇后数量,cnt表示方案数量
int vis[][*MAX+];
//v[0][]、v[1][]、v[2][]分别表示列、主对角线、副对角线是否存在皇后
// 为0时表示无皇后,非0则表示有,且v[0][4]=2表示第四列第二行存在皇后 void print() {
cout << LINE32 << endl;
cout << "第" << cnt << "个方案: " << endl;
for (int i = ; i <= n; i++) {
if (i != ) {
cout << ", ";
}
cout << "(" << vis[][i] << "," << i << ")";
}
cout << endl;
for (int i = ; i <= n; i++) {
for (int j = ; j <= n; j++) {
if (vis[][j] != i) {
cout << 'x';
} else {
cout << 'Q';
}
}
cout << endl;
}
} bool check(int row, int col) {// 检查是否可以在(row,col)这个坐标放置皇后
return !(vis[][col] || vis[][row-col+n] || vis[][row+col]);
}
void place(int x, int y, int *r2c) {// 在(x,y)的位置上放置皇后
vis[][y] = x;
vis[][x-y+n] = vis[][x+y] = ;
r2c[x] = y;
}
void remove(int x, int y) {// 移除(x,y)位置上的皇后
vis[][y] = vis[][x-y+n] = vis[][x+y] = ;
}
void solve(int n) {// 与非递归实现1的不同点在于,A.使用了vis[3][]加快了判断,B.回溯的具体操作是在vis[3][]上而不是r2c[]上
int r2c[n+];// 存放各行所放位置的列数,其实类似于递归实现1和非递归实现1中使用的queen[]
r2c[] = ;// 这里要初始化,否则最后要退出下面的循环时会数组越界,受影响的代码是63_42
int row = , col = ;
place(row, col, r2c);
row = ;//在(1,1)的位置上放置一个皇后,然后进入循环,开始寻找第二行放置的位置
while (row > ) {// row的值最后为0,因为所有情况都检查完时,第一行往上回溯,row值就为0
if (row > n) {
// 找到一个解,之后需要向上回溯:移除上一行的皇后,从上一行的下一列尝试放置皇后
cnt++;
if (PRINT_DETAILS) {
print();
}
row--;// row返回上一行
remove(row, r2c[row]);// 移除上一行中的皇后
col = r2c[row]+;// 此时的(row,col)为下一次尝试放置的位置
} else if (col > n) {
// 当前row行中的每一个位置都尝试并放置了,回溯
row--;
remove(row, r2c[row]);
col = r2c[row]+;
} else if (check(row, col)) {
// 找到一个符合的位置
place(row, col, r2c);// 放置皇后
row++;// 查找下一行放置的位置
col = ;// 并且是从第一列开始放置
} else {
// 这一列不符合,查找下一列
col++;
}
}
} int main() {
// input
cout << "输入皇后个数: ";
cin >> n;
// compute
clock_t begin = clock();
solve(n);
clock_t end = clock();
// output
cout << LINE32 << endl;
cout << n << "皇后问题一共有" << cnt << "种解决方案" << endl;
cout << LINE32 << endl;
cout << "回溯非递归算法实现2 解决" << n << "皇后问题耗时" << /*end-begin << "打点" <<*/(double)(end-begin)/CLOCKS_PER_SEC << "s" << endl;
return ;
}
// 14 3~5s
与回溯递归算法实现2对比
回溯递归算法实现2运行情况

回溯非递归算法实现2运行情况

非递归实现还是比递归实现慢一点,有点不符合预期。
N皇后问题 回溯非递归算法 C++实现2的更多相关文章
- 理解 Hanoi 汉诺塔非递归算法
汉诺塔介绍: 汉诺塔(港台:河内塔)是根据一个传说形成的数学问题: 最早发明这个问题的人是法国数学家爱德华·卢卡斯. 传说越南河内某间寺院有三根银棒,上串 64 个金盘.寺院里的僧侣依照一个古老的预言 ...
- N个数全排列的非递归算法
//N个数全排列的非递归算法 #include"stdio.h" void swap(int &a, int &b) { int temp; temp = a; a ...
- 八皇后问题-回溯法(MATLAB)
原创文章,转载请注明:八皇后问题-回溯法(MATLAB) By Lucio.Yang 1.问题描述 八皇后问题是十九世纪著名数学家高斯于1850年提出的.问题是:在8*8的棋盘上摆放8个皇后,使其不能 ...
- C# 递归与非递归算法与数学公式
1.递归 递归:程序调用自身的编程技巧称为递归(recursion). 优点是:代码简洁,易于理解. 缺点是:运行效率较低. 递归思想:把问题分解成规模更小,但和原问题有着相同解法的问题. 1)下面是 ...
- 汉诺塔问题(The Tower of Hanoi)的递归算法与非递归算法
非递归算法: 根据圆盘的数量确定柱子的排放顺序: 若n为偶数,按顺时针方向依次摆放 A B C: 若n为奇数,按顺时针方向依次摆放 A C B. 然后进行如下操作: (1)按顺时针方向把圆盘1从现在的 ...
- 二叉树(9)----打印二叉树中第K层的第M个节点,非递归算法
1.二叉树定义: typedef struct BTreeNodeElement_t_ { void *data; } BTreeNodeElement_t; typedef struct BTree ...
- 【转】Java实现折半查找(二分查找)的递归和非递归算法
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://wintys.blog.51cto.com/425414/94051 Java二分 ...
- 八皇后,回溯与递归(Python实现)
八皇后问题是十九世纪著名的数学家高斯1850年提出 .以下为python语句的八皇后代码,摘自<Python基础教程>,代码相对于其他语言,来得短小且一次性可以打印出92种结果.同时可以扩 ...
- N皇后问题--回溯法
1.引子 中国有一句古话,叫做“不撞南墙不回头",生动的说明了一个人的固执,有点贬义,但是在软件编程中,这种思路确是一种解决问题最简单的算法,它通过一种类似于蛮干的思路,一步一步地往前走,每 ...
随机推荐
- Python之split()函数
在Python的高级特性里有切片(Slice)操作符,可以对字符串进行截取.Python还提供split()函数可以将一个字符串分裂成多个字符串组成的列表. split()的语法挺简单的: str.s ...
- The import org.springframework cannot be resolved
刚开始学spring框架时import org.springframework.context.support.ClassPathXmlApplicationContext;报错 我建的是maven项 ...
- mysql字段数据类型、设置严格模式
表操作 今日内容 1.数据类型 建表的时候,字段都有对应的数据类型 整型 浮点型 字符类型(char与varchar) 日期类型 枚举与集合 2.约束条件 primary key unique key ...
- 用Python简单批量处理数据
近期碰到一个问题,两套系统之间数据同步出了差错,事后才发现的,又不能将业务流程倒退,但是这么多数据手工处理量也太大了,于是决定用Python偷个小懒. 1.首先分析数据. 两边数据库字段的值都是一样, ...
- Spring事物传播行为
Spring事物传播行为 Spring中事务的定义: Propagation(key属性确定代理应该给哪个方法增加事务行为.这样的属性最重要的部份是传播行为.)有以下选项可供使用: PROPAGATI ...
- [洛谷1437&Codevs1257]敲砖块<恶心的dp>
题目链接:https://www.luogu.org/problem/show?pid=1437#sub http://codevs.cn/problem/1257/ 不得不说,这个题非常的恶心,在初 ...
- c++ 重载、继承、多态
一.重载 1.函数重载 在同一个作用域内,可以声明几个功能类似的同名函数,但是这些同名函数的形式参数(指参数的个数.类型或者顺序)必须不同.您不能仅通过返回类型的不同来重载函数. #include & ...
- Spring Boot 中自定义 SpringMVC 配置,到底继承谁哪一个类或则接口?
看了这篇文章,写的非常的言简意赅,特此记录下: 1.Spring Boot 1.x 中,自定义 SpringMVC 配置可以通过继承 WebMvcConfigurerAdapter 来实现. 2.Sp ...
- NKOJ4330 逛公园
时间限制 : - MS 空间限制 : 565536 KB 评测说明 : 3s 问题描述 策策同学特别喜欢逛公园.公园可以看成一张N个点M条边构成的有向图,且没有 自环和重边.其中1号点是公园的入 ...
- 【cs224w】Lecture 6 - 消息传递 及 节点分类
目录 Node Classification Probabilistic Relational Classifier Iterative Classification Belief Propagati ...