小弟刚刚学习数据结构,遇到了一个问题,代码如下
[code="java"]
/**
- 二叉树的节点类
- @author se7en * */ public class JTreeNode { private int nValue;//节点的值 private JTreeNode leftChild;//节点的左指针 private JTreeNode rightChild;//节点的右指针 public JTreeNode(int nValue){ this.nValue = nValue; } public void setnValue(int nValue) { this.nValue = nValue; } public int getnValue() { return nValue; } public void setRightChild(JTreeNode rightChild) { this.rightChild = rightChild; } public JTreeNode getRightChild() { return rightChild; } public void setLeftChild(JTreeNode leftChild) { this.leftChild = leftChild; } public JTreeNode getLeftChild() { return leftChild; } }
[/code]
[code="java"]
public class JTree {
private JTreeNode root;//根节点
public void add(int nValue){
JTreeNode tem = new JTreeNode(nValue);
add(root,tem);
}
private void add(JTreeNode root,JTreeNode node){
//若树为空
if(root==null){
root = node;
return;
}
//若树不为空,则比该较节点与根节点的大小
else{
//若小于等于,则递归遍历左子树
if(node.getnValue()<=root.getnValue()){
add(root.getLeftChild(),node);
}
//若大于,则递归遍历右子树
else{
add(root.getRightChild(),node);
}
}
}
//中序遍历:根左右
public void middleTravel(JTreeNode root){
if(root == null){
System.out.println(root.getnValue()+" ");
}
else{
middleTravel(root.getLeftChild());
middleTravel(root.getRightChild());
}
}
}
[/code]
出问题的地方是在这个方法
[code="java"]
private void add(JTreeNode root,JTreeNode node){
//若树为空
if(root==null){
root = node;
return;
}
//若树不为空,则比该较节点与根节点的大小
else{
//若小于等于,则递归遍历左子树
if(node.getnValue()<=root.getnValue()){
add(root.getLeftChild(),node);
}
//若大于,则递归遍历右子树
else{
add(root.getRightChild(),node);
}
}
}
[/code]
我的想法是这样的:第一个传入参数,root为空,直接将node赋给root,第二次传入参数时,root不为空,则比较大小,进入第二层的递归。
问题就来了,不管我第几次传入参数,测试时,root的值都为空,也就是说每次递归都是只停留在第一次,一直无法进入二层递归,这是为什么?