Ниже приведен код. Индекс массива представляет маленькие символы (a-z), а индекс равен 26 (количество символов в английском алфавите). Это словарь слов, в котором дочерний элемент [знак ascii-значение-97] указывает на следующий узел. Концу слова присваивается bool terminal=true.
Все функции рекурсивны. В функции удаления мы должны пройти до конца слова символ за символом. Во время обхода при втором вызове рекурсивного удаления я теряю все свои ссылки и происходит NullPointerException
.
Строка кода, вызывающая проблемы, имеет комментарий перед ней. Сначала проверяется, существует ли слово в словаре или нет.
import java.io.File;
import java.util.Scanner;
public class xxx {
public static void main(String[] args) {
Trie trie = new Trie();
if (trie.delete(word)) {
System.out.println("Word deleted");
} else {
System.out.println("Word not present");
}
break;
}
case "S": { //Search for the word
String word = tokens[1];
if (trie.isPresent(word)) {
System.out.println("Word found");
} else {
System.out.println("Word not found");
}
}
Этот класс просто вызывает рекурсивные функции класса Node. Класс trie получает вызов от основного класса, а затем передает данные рекурсивным функциям в классе Node.
class Trie {
Node root;
public Trie() {
root = new Node();
}
boolean isPresent(String s) { // returns true if s is present, false otherwise
current = root;
for (int i = 0; i < s.length(); i++) {
if (current.children[(int) s.charAt(i) - 97] == null) {
return false;
} else {
current = current.children[(int) s.charAt(i) - 97];
}
}
if (current.terminal == false) {
return false;
}
return true;
}
boolean delete(String s) { // returns false if s is not present, true otherwise
if (!isPresent(s)) {
return false;
}
root.delete(root,s);
return true;
}
int membership() { // returns the number of words in the data structure
return root.membership(root, 0);
}
void listAll() { // list all members of the Trie in alphabetical orber
root.listAll(root, "");
}
}
Дети [значение ascii-97] будут ссылаться на узел, и эта ссылка будет представлять буквенный символ. OutDegree позаботится о том, чтобы была удалена только данная строка. Этот класс имеет все рекурсивные функции.
class Node {
boolean terminal;
int outDegree;
Node[] children;
public Node() {
terminal = false;
outDegree = 0;
children = new Node[26];
}
public void delete(Node x, String s) {
if (s.length() > 1){
if(i<s.length())
delete(children[s.charAt(0)-97],s.substring(1)); //this is where problem occurs
}
else if(children[((int)s.charAt(0))-97].outDegree>0)
terminal =false;
else if(children[((int)s.charAt(0))-97].outDegree==0){
children[((int)s.charAt(0))-97]=null;
return;
}
if(children[s.charAt(0)-97].outDegree==0)
children[s.charAt(0)-97]=null;
}
}