0

我有这个代码片段

class bst {
  public node root=null;

  bst() {
    root=null;
  }

  public void insert(int data) {  
    insert(this.root,data);
  }

  private void insert(node ro,int data) {
    if (ro==null) {
      print ("root is null");
      ro=new node(data);
    } else if (data>ro.data)
      insert(ro.right,data); 
    else
      insert(ro.left,data);
  }

  private void print (String str) 
  {
    System.out.println(str);
  }
}

当我insert像它一样调用函数时,insert(5); insert(8);它总是打印root is null

有什么问题??

4

1 回答 1

8

您的问题是方法中的ro变量insert只是对bst.ro. 这意味着如果您在方法内重置ro变量,只是引用的副本将指向new ro,最初传递的对象将保持不变。

您的问题是参数传递常见问题解答的前 1 个问题。我自己已经不止一次地回答了这个问题。检查出来

于 2010-01-17T14:33:59.410 回答