我需要使用带有数据、左和右的节点制作一棵二叉树。在我的 toString() 方法中,我使用了一个字符串生成器和一个 preOrderTraverse 方法。
我的 toString() 但是没有返回任何东西。任何想法为什么会这样?
private void preOrderTraverse(Node node, int depth, StringBuilder sb) {
for (int i = 1; i < depth; i++) {
sb.append(" ");
}
if (node == null) {
sb.append("null\n");
} else {
sb.append(node.data.toString());
sb.append("\n");
preOrderTraverse(node.left, depth + 1, sb);
preOrderTraverse(node.right, depth + 1, sb);
}
}
public String toString() {
StringBuilder sb = new StringBuilder();
preOrderTraverse(root, 0, sb);
return sb.toString();
}
public static void main(String[] args) {
BRT b = new BRT();
for (int i = 0; i < 15; i++){
Random generator = new Random();
Integer randomIndex = generator.nextInt( 11 );
b.add(randomIndex);
}
b.toString();
}
}