回溯算法之八皇后问题
来源:互联网 发布:如何安装centos 编辑:程序博客网 时间:2024/05/22 05:14
八皇后问题是一个古老而著名的问题,是回溯算法的典型例题。该问题是十九世纪著名的数学家高斯1850年提出:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上.
问题分析:
第一步 定义问题的解空间
这个问题解空间就是8个皇后在棋盘中的位置.
第二步 定义解空间的结构
可以使用8*8的数组,但由于任意两个皇后都不能在同行,我们可以用数组下标表示
行,数组的值来表示皇后放的列,故可以简化为一个以维数组x[9]。
第三步 以深度优先的方式搜索解空间,并在搜索过程使用剪枝函数来剪枝
根据条件:x[i] == x[k]判断处于同一列
abs(k-i) == abs(x[k]-x[i]判断是否处于同一斜线
我们很容易写出剪枝函数:
然后我们按照回溯框架一,很容易写出8皇后的回溯代码:
整个代码:
问题分析:
第一步 定义问题的解空间
这个问题解空间就是8个皇后在棋盘中的位置.
第二步 定义解空间的结构
可以使用8*8的数组,但由于任意两个皇后都不能在同行,我们可以用数组下标表示
行,数组的值来表示皇后放的列,故可以简化为一个以维数组x[9]。
第三步 以深度优先的方式搜索解空间,并在搜索过程使用剪枝函数来剪枝
根据条件:x[i] == x[k]判断处于同一列
abs(k-i) == abs(x[k]-x[i]判断是否处于同一斜线
我们很容易写出剪枝函数:
- bool canPlace(int k){
- for(int i = 1; i < k; i++){
- //判断处于同一列或同一斜线
- if(x[i] == x[k] || abs(k-i) == abs(x[k]-x[i])) return false;
- }
- return true;
- }
然后我们按照回溯框架一,很容易写出8皇后的回溯代码:
- void queen(int i){
- if(i > 8){
- print();
- return;
- }
- for(int j = 1; j <= 8; j++){
- x[i] = j;//记录所放的列
- if(canPlace(i)) queen(i+1);
- }
- }
整个代码:
- #include<iostream>
- #include<cmath>
- using namespace std;
- int x[9];
- void print(){
- for(int i = 1; i <= 8; i++)
- cout << x[i] << " ";
- cout << endl;
- }
- bool canPlace(int k){
- for(int i = 1; i < k; i++){
- //判断处于同一列或同一斜线
- if(x[i] == x[k] || abs(k-i) == abs(x[k]-x[i]))
- return false;
- }
- return true;
- }
- void queen(int i){
- if(i > 8){
- print();
- return;
- }
- for(int j = 1; j <= 8; j++){
- x[i] = j;
- if(canPlace(i)) queen(i+1);
- }
- }
- int main(){
- queen(1);
- return 0;
- }
- 回溯算法之八皇后问题
- 回溯算法之八皇后问题
- 回溯算法之八皇后问题
- 回溯算法之八皇后问题
- 回溯算法之八皇后问题
- c++算法之回溯 八皇后延伸 N皇后问题
- 回溯算法---八皇后问题
- 回溯算法-八皇后问题
- 八皇后问题回溯算法
- 回溯算法-八皇后问题
- 八皇后问题-回溯算法
- 八皇后问题-回溯算法
- 回溯算法:八皇后问题
- 八皇后 问题 回溯算法
- 算法[回溯]-八皇后问题
- 算法之5--回溯法解决八皇后问题
- 【C/C++】回溯经典算法之-->八皇后问题
- C++搜索与回溯算法之八皇后问题
- 从硬盘安装Fedora-9-i386-DVD, 采用Windows Boot.ini双系统引导
- .Net与WMI—序言
- 回溯算法的框架和基础
- 有关sdk 的介绍
- 原型设计之Axure RP pro
- 回溯算法之八皇后问题
- zk中程序加入组件的几个方法
- SDK/API等相关知识
- DES加解密算法
- 这样的需求如何设计测试用例
- 导出Tdbgrideh数据
- 公司现状及我的出路
- const指针右边法则
- zk基础概念之component,page,desktop