0

输出都非常不同,因此我在尝试修复它时遇到了一些麻烦。

这是一个:(0 停止填充列表)

run:
Enter an integer to be inserted or 0 to quit:
1
2
3
0
"printing P:"
1
2
3
"now copying:"
1
"done printing Q"
BUILD SUCCESSFUL (total time: 7 seconds)

这是另一个:

run:
Enter an integer to be inserted or 0 to quit:
1
2
3
-4
-5
-6
0
printing P
-6
-5
-4
1
2
3
now copying
-6
-5
-4
1
done printing Q
BUILD SUCCESSFUL (total time: 13 seconds)

还有一个,它有效:

run:
Enter an integer to be inserted or 0 to quit:
6
5
4
0
printing P
4
5
6
now copying
4
5
6
done printing Q
BUILD SUCCESSFUL (total time: 11 seconds)

所以它只复制输入的最小数字,除非有负数,在这种情况下它复制那些但只复制输入的最小正数。负数工作正常,只有按升序输入的正数不会复制。

这是课程:

public class Intcoll6
  {
    private int howmany;
private btNode c;

public Intcoll6()
  {
    howmany = 0;
    c = null;
  }
//we have to use this private class
private class btNode
  {
    int info;
    btNode left;
    btNode right;

    public btNode()
      {
        info = 0;
        left = null;
        right = null;
      }
  }
public boolean belongs(int i)
  {
    boolean result = false;
    btNode p = c;
    while ((p != null) && (p.info != i))
      {
        if (i < p.info)
          {
            p = p.left;
          }
        if (p.info > i)
          {
            p = p.right;
          }
        if (p != null)
          {
            result = true;
          }
      }
    return result;
  }
//I believe the problem is with this method
public void insert(int i)
  {
    btNode p = c;
    btNode pred = null;
    while ((p != null) && (p.info != i))
      {
        pred = p;
        if (i < p.info)
          {
            p = p.left;
          } else if (i > p.info)
          {
            p = p.right;
          }
      }
    if (p == null)
      {
        howmany = howmany + 1;
        p = new btNode();
        if (pred != null)
          {
            if (i < pred.info)
              {
                pred.left = p;
              }
            if (i > pred.info)
              {
                pred.right = p;
              }
            p.info = i;
          }
        if (pred == null)
          {
            c = p;
            p.info = i;
          }

      }
  }

public void omit(int i)
  {
    btNode p = c;
    btNode pred = null;
    while ((p != null) && (p.info != i))
      {
        pred = p;
        if (i < p.info)
          {
            p = p.left;
          }
        if (i > p.info)
          {
            p = p.right;
          }
      }
    if (p != null)
      {
        howmany--;
        if (pred != null)
          {
            if ((p.left == null) && (p.right == null))
              {
                if (p.info > pred.info)
                  {
                    pred.right = null;
                  } else
                  {
                    pred.left = null;
                  }
              } else if ((p.left != null) && (p.right == null))
              {
                if (p.info > pred.info)
                  {
                    pred.right = p.left;
                  } else
                  {
                    pred.left = p.left;
                  }
              } else if ((p.right != null) && (p.left == null))
              {
                if (p.info < pred.info)
                  {
                    pred.left = p.right;
                  } else
                  {
                    pred.right = p.right;
                  }
              } else if ((p.left != null) && (p.right != null))
              {
                if (p.info > pred.info)
                  {
                    btNode q = p;
                    btNode q1 = pred;
                    while (q != null)
                      {
                        q1 = q;
                        q = q.left;
                      }
                    p.info = q.info;
                    q1.left = null;

                  }
                if (p.info < pred.info)
                  {
                    btNode q = p;
                    btNode q1 = p;
                    while (q != null)
                      {
                        q1 = q;
                        q = q.right;
                      }
                    p.info = q.info;
                    q1.right = null;
                  }
              }
          }
        if (pred == null)
          {
            if ((p.left == null) && (p.right == null))
              {
                c = null;
              } else if ((p.left != null) && (p.right == null))
              {
                c = p.left;
              } else if ((p.left == null) && (p.right != null))
              {
                c = p.right;
              } else if ((p.right != null) && (p.left != null))
              {
                btNode q = p;
                btNode q1 = pred;
                while (q != null)
                  {
                    q1 = q;
                    q = q.right;
                  }
                p.info = q.info;
                q1.right = null;

              }
          }
      }
  }
private btNode copyTree(btNode tree)
{
    btNode result = null;
    if(tree != null)
    {
        btNode L;
        btNode R;
        L = copyTree(tree.left);
        R = copyTree(tree.right);
        result = new btNode();
        result.info = tree.info;
        result.left = L;
        tree.right = R;
    }
    return result;
}  
public void copy (Intcoll6 obj)
{
    if(this != obj)
    {
    howmany = obj.howmany;
    c = copyTree(obj.c);
    }
}
private static void printtree(btNode t)
  {
    if (t != null)
      {
        printtree(t.left);
        System.out.println(t.info);
        printtree(t.right);
      }
  }
public void print()
  {
    printtree(c);
  }
public boolean equals(Intcoll6 obj)
  {
    boolean result = (howmany == obj.howmany);
    btNode p = c;
    btNode q = obj.c;
    while ((p != null) && (q != null))
      {
        btNode pred = p;
        if ((p.info == q.info))
          {
            if (p.info >= pred.info)
              {
                p = p.right;
                q = q.right;
              }
          }
        if ((p == null) && (q == null))
          {
            result = true;
          }
      }
    return result;
  }  
  }

司机:

import intcoll6.Intcoll6;
import java.util.*;
import static intcoll6.Intcoll6Client.SENTINEL;
public class Driver6
  {
int value;
public static final int SENTINEL = 0;
public static void main(String[] args)
  {
    System.out.println("Enter an integer to be inserted or 0 to quit:");
    int value;
    Scanner keyboard = new Scanner(System.in);
    value = keyboard.nextInt();
    Intcoll6 P = new Intcoll6();
    while (value != SENTINEL)
      {
        P.insert(value);
        value = keyboard.nextInt();
      }
    System.out.println("printing P");
    P.print();
    System.out.println("now copying");
    Intcoll6 Q = new Intcoll6();
    Q.copy(P);
    Q.print();
    System.out.println("done printing Q");
  }
  }

这是正确的copyTree方法:

private btNode copyTree(btNode tree)
      {
    btNode test = null;
    if (tree != null)
      {
        test = new btNode();
        test.info = tree.info;
        test.left = copyTree (tree.left);
        test.right = copyTree(tree.right);
      }
    return test;
  }
4

1 回答 1

0

你从来没有在你的复制语句中正确设置正确的树。
说 tree.right = R 是将右树的副本分配给发送给方法的参数。
您应该将树复制到局部变量result

退出此方法后,树右侧的所有内容都丢失了,因此它永远不会打印其余部分,因为它只知道树的左侧。

private btNode copyTree(btNode tree)
{
    btNode result = null;
    if(tree != null)
    {
        btNode L;
        btNode R;
        L = copyTree(tree.left);
        R = copyTree(tree.right);
        result = new btNode();
        result.info = tree.info;
        result.left = L;
        //wrong//--> tree.right = R;
        //Should be// -- > result.right = R;
    }
    return result;
}  
于 2013-10-13T15:46:42.727 回答