算法谜题 php,JavaScript实现N皇后问题算法谜题解答_javascript技巧

谜题

N皇后问题。将N个皇后放置在NxN的国际象棋棋盘上,其中没有任何两个皇后处于同一行、同一列或同一对角线上,以使得它们不能互相攻击。

策略

回溯法。

JavaScript解

以8皇后问题为例:

代码如下:

/**

* Created by cshao on 12/28/14.

*/

function getNQueens(order) {

if (order < 4) {

console.log('N Queens problem apply for order bigger than 3');

return;

}

var nQueens = [];

var backTracking = false;

rowLoop:

for (var row=0; row

if (nQueens[row] === undefined) {

nQueens[row] = [];

}

for (var col=0; col

if (nQueens[row][col] === 0) {

continue;

} else if (backTracking && nQueens[row][col] == 1) {

if (col === order-1) {

resetRow(nQueens, order, row);

row = row - 2;

continue rowLoop;

}

nQueens[row][col] = 0;

backTracking = false;

continue;

}

nQueens[row][col] = 1;

if (isQueenValid(nQueens, row, col)) {

continue rowLoop;

} else if (col == order-1) {

backTracking = true;

resetRow(nQueens, order, row);

row = row - 2;

continue rowLoop;

} else {

nQueens[row][col] = 0;

continue;

};

}

}

return nQueens;

}

function resetRow(nQueens, order, row) {

for (var col=0; col

nQueens[row][col] = undefined;

}

}

function isQueenValid(nQueens, row, col) {

for (var i=0; i

if (nQueens[row][i] == 1) {

return false;

}

}

for (var j=1; j

if (nQueens[row-j][col]==1 || (nQueens[row-j][col-j]!=undefined && nQueens[row-j][col-j]==1) || (nQueens[row-j][col+j]!=undefined && nQueens[row-j][col+j]==1)) {

return false;

}

}

return true;

}

function printQueens(queens) {

for (var row=0; row

var rowText = '';

for (var col=0; col

if (queens[row][col]===undefined) {

queens[row][col] = 0;

}

rowText = rowText + queens[row][col] + ' ';

}

console.log(rowText);

}

}

var queens = getNQueens(8);

printQueens(queens);

结果

代码如下:

1 0 0 0 0 0 0 0

0 0 0 0 1 0 0 0

0 0 0 0 0 0 0 1

0 0 0 0 0 1 0 0

0 0 1 0 0 0 0 0

0 0 0 0 0 0 1 0

0 1 0 0 0 0 0 0

0 0 0 1 0 0 0 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值