gpt4 book ai didi

java - 使用文本文件填充二叉搜索树

转载 作者:行者123 更新时间:2023-12-01 15:29:57 25 4
gpt4 key购买 nike

我正在尝试用文本文件填充二叉搜索树,但在实现插入功能时遇到很多麻烦。我正确读取输入还是我的代码?

读取文件的代码:

import java.io.*;
import java.util.Scanner;

public class Driver {
public static void main(String[]args) throws IOException
{
//Checks if there is a correct number of arguments passed through the command line.
if (args.length != 1)
{
quitError("Tree command word arguments expected");
}

String inputFile = args[0];
BST btree = new BST();

try
{
BufferedReader input = new BufferedReader(new FileReader(inputFile));

//Scans each word from the input and prints it out
String word = input.readLine();
while (word != null)
{
btree.insert(word);
word = input.readLine();
}
return;

} catch(FileNotFoundException filenotfoundexception) //Catches file not found exception
{
System.out.println("File not found.");
}
catch(IOException ioexception) //Catches input/output exception
{
System.out.println("File input error occured!");
}

}

//Displays an error message, program exits
public static void quitError(String msg)
{
System.out.println(msg);
System.out.println("Program will now quit.");
System.exit(0);
}
}

二叉搜索树节点的代码:

public class BSTNode {
protected String data;
protected BSTNode left, right;

public BSTNode()
{
left = null;
right = null;
}

public BSTNode(String data)
{
this(data,null,null);
}

public BSTNode(String data, BSTNode lt, BSTNode rt)
{
this.data = data;
left = lt;
right = rt;
}
}

二叉搜索树的代码:

public class BST {
protected BSTNode root = null;
public BST(){}

public void clear()
{
root = null;
}

public boolean isEmpty()
{
return root == null;
}


public void insert(String data)
{
BSTNode p = root, prev = null;
while (p != null) {
prev = p;
if (p.data.compareTo(data) < 0)
p = p.right;
else p = p.left;
}
if (root == null)
root = new BSTNode(data);
else if (prev.data.compareTo(data) < 0)
prev.right = new BSTNode(data);
else prev.left = new BSTNode(data);
}

public void inorder()
{
inorder(root);
}

private void inorder(BSTNode p)
{
if (p != null)
{
inorder(p.left);
System.out.print(p.data + " ");
inorder(p.right);
}
}

public void breadthFirst()
{
BSTNode p = root;
Queue queue = new Queue();
if (p != null)
{
queue.enqueue(p);
while (!queue.isEmpty())
{
p = (BSTNode) queue.dequeue();
System.out.print(p.data + " ");
if (p.left != null)
queue.enqueue(p.left);
if (p.right != null)
queue.enqueue(p.right);
}
}
}


}

最佳答案

除非文件每行只有一个单词,否则您将会遇到麻烦。缓冲阅读器为您提供整行内容。是一个词还是一个句子?

您的 insert() 方法为空。没有它,什么都不会发生。把一些代码放进去,你可能会有更好的运气。

所以在我看来你有两个问题:

  1. 除非每行一个单词,否则您的输入不正确。如果每一行都是一个句子,您必须将其标记为单词。
  2. 您的插入方法不执行任何操作。难怪你的树不起作用。

关于java - 使用文本文件填充二叉搜索树,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9660559/

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