广度首先遍历对象

时间:2011-03-23 20:32:16

标签: javascript jquery json breadth-first-search

我正在制作一个解决益智游戏的程序,它会在棋盘上找到所有可能的移动并将所有可能产生的棋盘放在一个对象中。然后它会找到所得到的电路板的所有可能移动,依此类推。该对象看起来像这样:

{
  "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":[{}]
    }]
}

我可以弄清楚如何从顶层板添加可能的移动,但是我无法弄清楚如何在第二层中遍历所有生成的板并找出它们可能的移动,然后循环遍历所有三级板等。如何使用广度优先搜索添加可能的移动并遍历对象?

3 个答案:

答案 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)

我没有JavaScript描述,但我通常会通过保留未探测节点的队列来实现。

  1. 仅从队列中的根节点开始。
  2. 从队列前面弹出一个项目
  3. 探索它将探索期间找到的所有节点添加到队列后面
  4. 检查队列中是否有任何节点(如果有返回步骤2)
  5. 你完成了
  6. 维基百科页面上还有一些伪足以及更多解释 HERE

    同样快速的谷歌搜索也出现了类似的算法,可以根据您的需要进行调整 HERE