八皇后这个经典的算法网上有很多种思路,我学习了之后自己实现了一下,现在大概说说我的思路给大家参考一下,也算记录一下,以免以后自己忘了要重新想一遍。

八皇后问题

八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例。该问题是国际西洋棋棋手马克斯·贝瑟尔于1848年提出:在8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。

工作原理

首先从定义知道,两个皇后都不能处于同一行,所以第0个皇后放在第0行,第一个皇后放在第1行,以此类推。

先在第0行第0个格子(0,0)放一个皇后0,接着把处于同一行、同一列或同一斜线上的格子都标记为皇后0;

然后把皇后1放到第1行标记为-1的格子中,以此类推直到放下皇后7(即最后一个皇后)。

若中途出现放皇后 iQueen时,第 iQueen行所有格子已经被全部标记,即if( arr[ iQueen*n + i ].index == -1 )的判断,则回溯到上一层函数(其实就是没有进入到if分支,所有没有进行递归了,代码执行完自然会跳回上一层函数继续执行)。

注意此时的执行环境(exection context)已经变了,所有setQueen函数内定义的变量全部回溯到上一层函数递归到下一层函数前的状态,即执行setQueen( iQueen + 1 );这行代码前的状态,例如递归前i=2,iQueen=1,无论下一层函数里的i和iQueen怎样变化,回溯后还是i=2,iQueen=1,然后紧接着执行未执行完的代码。

下面是执行顺序大概的图解:

执行顺序:1.if-->1.1-->1.2-->1.递归-->2.if-->2.1-->2.2-->2.递归-->3.if-->2.回溯-->1.回溯(前面的标号表示第几层)

var n = 8;//总行(列)数  8*8
var iCount = 0;//n皇后的解法数
//arr是长度为n*n的一维数组,保存着n*n个对象(li)并有各自的坐标,默认index都为-1,表示没有被任何皇后标记过 arr[ i*n + j ].y = i; arr[ i*n + j ].x = j;
for(var i=0;i<n;i++){
for(var j=0;j<n;j++){
arr[ i*n + j ].x = j;
arr[ i*n + j ].y = i;
//arr[ i*n + j ].innerHTML = j + ',' + i;
}
}
//iQueen从0开始,即皇后0
function setQueen(iQueen){ if( iQueen == n ){
iCount++;
console.log(iCount)
return;
} for(var i=0;i<n;i++){ if( arr[ iQueen*n + i ].index == -1 ){
arr[ iQueen*n + i ].index = iQueen;
//arr[ iQueen*n + i ].innerHTML = iQueen;
var x = arr[ iQueen*n + i ].x;
var y = arr[ iQueen*n + i ].y; for(var j=0;j<arr.length;j++){
if( arr[j].index == -1 && (arr[j].x == x || arr[j].y == y || arr[j].x - arr[j].y == x - y || arr[j].x + arr[j].y == x + y) ){
arr[j].index = iQueen;
//arr[j].innerHTML = iQueen;
}
}
//执行到这里,就会跳到下一层函数中,在执行完下一层的函数后,才会回溯到上一层继续执行for循环(此时的for循环是上一层的for循环),包括后面的所有代码
//需要注意的是,例如当前函数的iQueen=1,跳到下一层函数 iQueen=2,下一层函数执行完后,回溯到上一层,此时的执行环境已经是上一层的执行环境了,即iQueen是等于1,而不是等于2
//递归
setQueen( iQueen + 1 ); //回溯
for(var j=0;j<arr.length;j++){
if( arr[j].index == iQueen ){
arr[j].index = -1;
//arr[j].innerHTML = -1;
}
} }
}
}

JS算法之八皇后问题(回溯法)的更多相关文章

  1. noj算法 8皇后打印 回溯法

    描述: 输出8皇后问题所有结果. 输入: 没有输入. 输出: 每个结果第一行是No n:的形式,n表示输出的是第几个结果:下面8行,每行8个字符,‘A’表示皇后,‘.’表示空格.不同的结果中,先输出第 ...

  2. 八皇后问题-回溯法(MATLAB)

    原创文章,转载请注明:八皇后问题-回溯法(MATLAB) By Lucio.Yang 1.问题描述 八皇后问题是十九世纪著名数学家高斯于1850年提出的.问题是:在8*8的棋盘上摆放8个皇后,使其不能 ...

  3. 算法入门经典-第七章 例题7-4-1 拓展 n皇后问题 回溯法

    实际上回溯法有暴力破解的意思在里面,解决一个问题,一路走到底,路无法通,返回寻找另   一条路. 回溯法可以解决很多的问题,如:N皇后问题和迷宫问题. 一.概念 回溯算法实际类似枚举的搜索尝试过程,主 ...

  4. 『嗨威说』算法设计与分析 - 回溯法思想小结(USACO-cha1-sec1.5 Checker Challenge 八皇后升级版)

    本文索引目录: 一.回溯算法的基本思想以及个人理解 二.“子集和”问题的解空间结构和约束函数 三.一道经典回溯法题点拨升华回溯法思想 四.结对编程情况 一.回溯算法的基本思想以及个人理解: 1.1 基 ...

  5. HDU 2553 n皇后问题(回溯法)

     DFS Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u   Description ...

  6. N皇后问题--回溯法

    1.引子 中国有一句古话,叫做“不撞南墙不回头",生动的说明了一个人的固执,有点贬义,但是在软件编程中,这种思路确是一种解决问题最简单的算法,它通过一种类似于蛮干的思路,一步一步地往前走,每 ...

  7. JAVA实现N皇后问题(回溯法)

    package com.leetCode; /** * Follow up for N-Queens problem. Now, instead outputting board configurat ...

  8. N皇后问题 回溯法 C/C++

    一:问题描述 N皇后问题(含八皇后问题的拓展,规则同四皇后):在N*N的棋盘上,放置N个皇后,要求每一横行每一列,每一对角线上均只能放置一个皇后,求解可能的方案及方案数. 二:代码及结果如下 #inc ...

  9. 8皇后-----回溯法C++编程练习

    /* * 八皇后问题回溯法编程练习 * 在8×8的棋盘上,放置8个皇后,两个皇后之间不能两两攻击 * 也即,直线,垂直45度.135度方向不能出现两个皇后 * * copyright Michael ...

随机推荐

  1. P3622 [APIO2007]动物园

    题目链接 题意分析 这是一道状压\(DP\)的题 一个人只可以欣赏到\(5\)只动物 显然可以状压 我们用\(dp[i][j]\)表示当前\([i,i+4]\)中这\(5\)只动物的状态\(j\) 在 ...

  2. JavaScript变量那些事

    引言 JavaScript的变量本质是松散类型的,也就是说其变量就是用于保存特定值的一个名字,变量的值和数据类型可以在脚本执行的生命周期中发生变化.这是一个很有趣很强大的特性,但是也是一个极容易出错误 ...

  3. LINUX云服务器 安装 nginx

    什么是nginx? 是一个高性能的 HTTP 和反向代理服务器,也是一个IMAP/POP3/SMTP 代理服, 是一个asynchronousservers异步服务器 为什么使用nginx? 因为它的 ...

  4. OpenFoam+CFDEM+Liggghts安装耦合

    这里安装的时间节点为:2018.10.29,安装的是目前的最新版本CFDEM,支持到与OpenFoam-5.x的耦合. 1. 先安装openfoam:https://openfoam.org/down ...

  5. [Re:从零开始的分布式] 0.x——分布式基础概念

    分布式的特点 1. 分布式 2. 对等性 3. 并发性 4. 缺乏全局时钟 5. 故障总是会发生 分布式环境的问题 1. 网络不可靠 2. 网络分区 3. 节点故障 CAP理论 一致性 可用性 分区容 ...

  6. STM32F103RE引脚功能整理

  7. Sublime Text 3新建工程

    1. 创建工程 Project > Add Folder to Project 这时在sidebar中将出现刚刚添加的文件目录,如果还需要添加其他目录,则重复这一操作即可. 2. 保存工程 Pr ...

  8. 【Maven学习】maven-enforcer-plugin的使用

    我们会经常碰到这样的问题,在pom中引入了一个jar,里面默认依赖了其他的jar包.jar包一多的时候,我们很难确认哪些jar是我们需要的,哪些jar是冲突的.此时会出现很多莫名其妙的问题,什么类找不 ...

  9. 《LeetBook》leetcode题解(7): Reverse Integer[E]——处理溢出的技巧

    我现在在做一个叫<leetbook>的开源书项目,把解题思路都同步更新到github上了,需要的同学可以去看看 书的地址:https://hk029.gitbooks.io/leetboo ...

  10. CentOS和Ubuntu系统下安装 HttpFS (助推Hue部署搭建)

    不多说,直接上干货! 我的集群机器情况是 bigdatamaster(192.168.80.10).bigdataslave1(192.168.80.11)和bigdataslave2(192.168 ...