Это код обхода порядка уровней:
public void bfsTraveral() {
if (root == null) {
throw new NullPointerException("The root cannot be null.");
}
int currentLevelNodes = 0;
int nextLevelNodes = 0;
final Queue<TreeNode> queue = new LinkedList<TreeNode>();
queue.add(root);
currentLevelNodes++;
while(!queue.isEmpty()) {
final TreeNode node = queue.poll();
System.out.print(node.element + ",");
currentLevelNodes--;
if (node.left != null) { queue.add(node.left); nextLevelNodes++;}
if (node.right != null) { queue.add(node.right); nextLevelNodes++;}
if (currentLevelNodes == 0) {
currentLevelNodes = nextLevelNodes;
nextLevelNodes = 0;
System.out.println();
}
}
На мой взгляд, пространственная сложность должна быть O(2^h), где h — высота дерева, просто потому, что это максимальный размер, достижимый очередью во время выполнения. В Интернете я нахожу сложность пространства как O (n). Это звучит неправильно для меня. Пожалуйста, поделитесь своим мнением.
Спасибо,
h
? Что такоеn
? - person Oliver Charlesworth   schedule 14.07.2013