私は大学でのプロジェクトで問題を抱えていました。ダブル ハッシュされた文字列オブジェクトを返すクラスにダブル ハッシュ メソッドを記述する必要があります。JavaにはhashCode()メソッドが組み込まれているという事実を考えると、これは比較的簡単だと思いましたが、hashCodeを2回繰り返してもまったく同じ値が返されるようです。例えば:
StringHashCode.java:
public class StringHashCode implements HashCode{
@Override
public int giveCode(Object obj) {
return obj.hashCode();
}
}
スペル.java
while(dict_fwr.hasNextWord())
{
String derp = dict_fwr.nextWord();
System.out.print(derp + "(hash value = " + impl.giveCode(derp) + ")" + "(Double hashed = " + impl.giveCode(impl.giveCode(derp)) + ")\n" );
}
出力からの抜粋:
midwest(hash value = 1055712247)(Double hashed = 1055712247)
partakes(hash value = 1188620491)(Double hashed = 1188620491)
interspersed(hash value = 486466540)(Double hashed = 486466540)
marginally(hash value = 1971567014)(Double hashed = 1971567014)
bemoans(hash value = -223340895)(Double hashed = -223340895)
bankrupt(hash value = -1858199613)(Double hashed = -1858199613)
transpire(hash value = 1052958868)(Double hashed = 1052958868)
conspire(hash value = -567922531)(Double hashed = -567922531)
dict は単語のリストを含むファイルで、クラスは講師が作成したクラスで、次の文字列を返し、別の単語があるかどうかをチェックします。