日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

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

發布時間:2025/4/16 php 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 算法谜题 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

總結

以上是生活随笔為你收集整理的算法谜题 php,JavaScript实现N皇后问题算法谜题解答_javascript技巧的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。