我正在制作一个解决益智游戏的程序,它会在棋盘上找到所有可能的移动并将所有可能产生的棋盘放在一个对象中。然后它会找到所得到的电路板的所有可能移动,依此类推。该对象看起来像这样:
{
"board": {
"starts": [[0,0],[0,3]],
"blocks": [[3,0],[3,3]],
"ends": [[2,4]]
},
"possibleMoves": [
{
"board": {
"starts": [[0,0],[2,3]],
"blocks": [[3,0],[3,3]],
"ends": [[2,4]]
},
"possibleMoves":[
{
"board": {},
"possibleMoves": [{}]
}
]
},
{
"board": {
"starts": [[0,3]],
"blocks": [[3,0],[3,3]],
"ends": [[2,4]]
},
"possibleMoves":[{}]
}]
}
我可以弄清楚如何从顶层板添加可能的移动,但是我无法弄清楚如何在第二层中遍历所有生成的板并找出它们可能的移动,然后循环遍历所有三级板等。如何使用广度优先搜索添加可能的移动并遍历对象?
答案 0 :(得分:21)
递归。
function traverse(state) {
handle(state.board);
if (state.possibleMoves) {
$.each(state.possibleMoves, function(i, possibleMove) {
traverse(possibleMove);
});
}
}
编辑:对于广度优先搜索,请尝试这样的操作。它不使用递归,而是遍历不断增长的队列。
function traverse(state) {
var queue = [],
next = state;
while (next) {
if (next.possibleMoves) {
$.each(next.possibleMoves, function(i, possibleMove) {
queue.push(possibleMove);
});
}
next = queue.shift();
}
}
答案 1 :(得分:2)
尚未完全测试:
var oo = {
board: {
starts: [[0,0],[0,3]],
blocks: [[3,0],[3,3]],
ends: [[2,4]]
},
possibleMoves: [{
board: {
starts: [[0,0],[2,3]],
blocks: [[3,0],[3,3]],
ends: [[2,4]]
},
}],
};
function traverseObject (o) {
for (var prop in o) {
if (typeof o[prop] == "array" || typeof o[prop] == "object") {
traverseObject(o[prop]);
console.log(prop);
} else {
console.log(prop, "=", o[prop]);
}
}
}
traverseObject(oo);
答案 2 :(得分:1)