Java のオブジェクトへの参照が copy によって渡されることはわかっていますが、コピーは引き続き system の同じメモリを指しているため、別の function で複合オブジェクトの一部のデータを更新した後、元のデータを維持する必要があります。しかし興味深いことに、ここで何かがうまくいかない。私はTriesで働いています。
これが Trie の私の実装です。いくつかのカスタム ルールがあるため、かなりカスタムな実装です。
public class Trie {
boolean isEnd;
Trie trie[] = new Trie[256];
ArrayList<Integer> indexNode;
public static Trie createTrieNode() {
Trie temp = new Trie();
temp.isEnd = false;
temp.indexNode = new ArrayList<Integer>();
for (int i = 0; i < temp.trie.length; i++) {
temp.trie[i] = null;
}
return temp;
}
public static void insertIntoTrie(Trie root, char[] alpha, int index, int i) {
if (root == null)
root = createTrieNode();
if (i < alpha.length)
insertIntoTrie(root.trie[alpha[i] - 'a'], alpha, index, i + 1);
else {
if (root.isEnd == true) {
root.indexNode.add(index);
} else {
root.isEnd = true;
root.indexNode.add(index);
}
}
}
}
今、私のオブジェクトroot
はこのクラスから来ており、デバッガーでは、このステートメントが実行されているのを見ることができます:root.isEnd = true;
クラス:
public class AnagramsTogether {
public Trie root = new Trie();
public void printAnagrams(String[] anagrams){
char[] buffer;
for (int i = 0; i < anagrams.length; i++) {
buffer = anagrams[i].toCharArray();
Arrays.sort(buffer);
Trie.insertIntoTrie(root, buffer, i, 0);
}
AnagramsUtil.anagramUtil(root,anagrams);
}
}
しかし、いつroot
ここに渡されたときAnagramsUtil.anagramUtil(root,anagrams);
public class AnagramsUtil {
public static void anagramUtil(Trie root, String[] anagrams) {
if (root.isEnd == true) {
for (Iterator<Integer> iterator = root.indexNode.iterator(); iterator
.hasNext();) {
Integer integer = (Integer) iterator.next();
System.out.println(anagrams[integer]);
}
} else {
for (int i = 0; i < root.trie.length; i++) {
if (root.trie[i] == null)
continue;
anagramUtil(root.trie[i], anagrams);
}
}
}
}
public class Anagram{
public static String string[] = {"cat", "dog", "god","act", "tac","gdo"};
public static void main(String args){
new AnagramsTogether().printAnagrams(Anagram.string);
}
}
このステートメントif (root.isEnd == true)
は決して実行されず、これも決して実行されません anagramUtil(root.trie[i], anagrams);
。プログラムはcontinue
ステートメントを実行し続けます。私はすでにroot.trie[i]
値を受け取っているのを見たので、これは当てはまりません。なぜこれが起こるのですか?私はJavaにかなり慣れていません。