gpt4 book ai didi

java - 比较器不适用于二叉树

转载 作者:行者123 更新时间:2023-12-01 11:42:04 25 4
gpt4 key购买 nike

我有这个东西

比较器.java

public interface Comparator<T> {
public int compareTo(int num);
}

valueComparator.java

public class valueComparator implements Comparator<Tree.Node> {
@Override
public int compareTo(Tree.Node obj, int number) {
if (obj.getDataNumber() == number) {
return 0;
}
else if (obj.getDataNumber() < number) {
return -1;
}
else return 1;
}
}

树.java

public class Tree {
public Node root;

Tree() {
}

public static class Node {

Node(int number, String str, boolean flag) {
dataNumber = number;
dataText = str;
dataBool = flag;
}

public int getDataNumber() {
return this.dataNumber;
}

public String getDataText() {
return this.dataText;
}

public boolean getDataBool() {
return this.dataBool;
}

public void setDataText(String text) {
this.dataText = text;
}

public void isDataBool(boolean flag) {
this.dataBool = flag;
}

Node left;
Node right;
private int dataNumber;
private String dataText;
private boolean dataBool;

}

public void binaryTree() {
root = null;
}

public boolean search(int number) {
return search(root, number);
}

valueComparator comp = new valueComparator();

private boolean search(Node node, int number) {
if (node == null) {
return false;
}
if (comp.compareTo(node, number) == 0) {
return true;
}
if (comp.compareTo(node, number) == -1) {
return search(node.left, number);
}
else {
return search(node.right, number);
}
}

public void insertLeaf(int number, String str, boolean flag) {
root = insertLeaf(root, number, str, flag);
}
private Node insertLeaf(Node node, int number, String str, boolean flag) {
if (node == null) {
node = new Node(number, str, flag);
} else {
if (number < node.dataNumber) {
node.left = insertLeaf(node.left, number, str, flag);
}
else if (number > node.dataNumber) {
node.right = insertLeaf(node.right, number, str, flag);
}
else {
System.out.println("The element is already in the tree.");
}
}
return node;
}
}

测试.java

public class Test {
public static void main(String args[]) {

Tree binTree = new Tree();
binTree.binaryTree();
binTree.insertLeaf(5, "text2", true);
binTree.insertLeaf(4, "text4", false);
binTree.insertLeaf(1, "text1", true);
binTree.insertLeaf(3, "text3", true);
binTree.insertLeaf(2, "text5", false);
System.out.println("Element 3 found: " + binTree.search(3));
// Element 3 found: false
}
}

我应该用比较器进行搜索,但我无法理解其中的逻辑。 compareTo 方法本身有效,但它停留在搜索的递归调用上。在第一遍之后,如果compareTo的返回不= 0,则它以null进入并退出递归并返回false。这意味着如果我将树的第一个元素设置为“3”,则 search(3) 将返回 true,但如果它与 3 不同,则返回 false,甚至不会在树中查找它。

最佳答案

当您插入一个数字时,您可以直接将其与节点的值进行比较,如果该数字小于当前节点中存储的值,则按照左侧指针。

但是,当您搜索数字时,您会使用比较器,它将节点的值与给定的数字进行比较(注意相反的顺序!),如果该数字小于当前节点,您可以点击右侧链接。

根据需要使用直接比较或比较器 - 但在任何地方都使用相同的方法。

关于java - 比较器不适用于二叉树,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29445841/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com