【发布时间】:2010-12-23 11:12:28
【问题描述】:
我有一个需要搜索的二叉树。我不是在搜索树的一个特定节点,而是搜索树的每个节点以获取有关它们的信息。我现在有一个简单的递归搜索,但每次运行时都会出现堆栈溢出错误。它是一棵深度为 7 的完整二叉树...
if (curDepth < 6 && !searchedNodes[curID * 2])
depthSearch(curNode.getRight());
if (curDepth < 6 && !searchedNodes[curID * 2 + 1])
depthSearch(curNode.getLeft());
if (curID != 1 && !searchedNodes[(int) (curID / 2)])
depthSearch(curNode.getParent());
curID == 1 对应根节点,所以我需要检查它是 不是父母。 searchedNodes 是为了确保我不搜索 同一个节点两次。关于如何做到这一点的任何想法?
编辑:这是整个搜索方法
public void depthSearch(AntTree curNode) {
boolean[] searchedNodes = new boolean[128];
if (curNode == null)
return;
int curID = curNode.getID();
searchedNodes[curID] = true;
if (curNode.getFood() > 0) {
AntScript.foodLocs[curID] = 1;
} else {
Ant6Script.foodLocs[curID] = 0;
}
Ant[] ants = curNode.getAnts();
boolean containsWorker = false, containsSoldier = false;
if (ants != null) {
for (int i = 0; i < ants.length; i++) {
if (ants[i].type().equals("Worker")
&& ants[i].teamID() != AntScript.myTeamID) {
containsWorker = true;
} else if (ants[i].type().equals("Soldier")
&& ants[i].teamID() != AntScript.myTeamID) {
containsSoldier = true;
} else if (ants[i].type().equals("Queen")
&& ants[i].teamID() != AntScript.myTeamID) {
AntScript.enemyQueenLoc = curID;
}
}
}
if (containsWorker)
AntScript.enemyWorkerLocs[curID] = 1;
else
AntScript.enemyWorkerLocs[curID] = 0;
if (containsSoldier)
AntScript.enemySoldierLocs[curID] = 1;
else
AntScript.enemySoldierLocs[curID] = 0;
AntScript.viewedNodeLocs[curID] = 1;
int curDepth = (int) (Math.log(curID) / Math.log(2));
if (AntScript.viewedNodeLocs[(int) (curID / 2)] == 0
|| (curDepth < 6 && AntScript.viewedNodeLocs[curID * 2 + 1] == 0)
|| (curDepth < 6 && AntScript.viewedNodeLocs[curID * 2] == 0)) {
if (curDepth < 6
&& AntScript.viewedNodeLocs[curID * 2] == 0
&& !searchedNodes[curID * 2]) {
depthSearch(curNode.getLeft());
}
if (curDepth < 6
&& AntScript.viewedNodeLocs[curID * 2 + 1] == 0
&& !searchedNodes[curID * 2 + 1]) {
depthSearch(curNode.getRight());
}
if (curID != 1
&& AntScript.viewedNodeLocs[(int) (curID / 2)] == 0
&& !searchedNodes[(int) (curID / 2)]) {
depthSearch(curNode.getParent());
}
} else {
if (curDepth < 6 && !searchedNodes[curID * 2]) {
depthSearch(curNode.getRight());
}
if (curDepth < 6 && !searchedNodes[curID * 2 + 1]) {
depthSearch(curNode.getLeft());
}
if (curID != 1 && !searchedNodes[(int) (curID / 2)]) {
depthSearch(curNode.getParent());
}
}
}
viewedNodeLocs 数组的目的是因为我有很多蚂蚁在板上执行来自不同节点的搜索,并且最好通过一个以前没有搜索过的节点进行搜索而不是一个已经搜索过的节点。我不能只进行一次大搜索然后完成,因为我对下一个节点的请求应该在来自一只蚂蚁的 13 次请求后返回 null(这整件事来自我正在为游戏编程的蚂蚁 AI)
【问题讨论】:
-
信息不足。发布整个递归搜索例程。
-
没有对您实际尝试做的事情的描述使得很难评估您所写的内容。对于一个相对简单的问题,这看起来非常复杂,并且有一些明显的错误。最重要的是,每次递归调用都会创建自己的 searchedNodes 副本并设置一个元素。再往下的测试只查看当前调用的 searchedNodes 并且看不到其他调用设置的任何值。你能发布目标的描述吗?
标签: java search recursion binary-tree