gpt4 book ai didi

Java实现-如何提高哈希表的速度

转载 作者:行者123 更新时间:2023-12-01 22:41:33 25 4
gpt4 key购买 nike

我正在实现一个哈希表(根据要求)。它在小输入时工作正常,但不幸的是在处理大量输入时它太慢了。我尝试了 BufferedInputStream ,但没有任何区别。基本上我按照下面的逻辑实现了它。有什么想法可以提高速度吗?是否有特定功能导致性能不佳?或者我们可能需要关闭扫描仪?

 int [] table = new int [30000];// creat an array as the table
Scanner scan = new Scanner (System.in); //use scanner to read the input file.
while (scan.hasNextLine()) {
//read one line at a time, and a sequence of int into an array list called keys
// functions used here is string.split(" ");
}
hashFuction{
//use middle-squaring on each elements to the array list keys.
// Math.pow() and % 30000, which is the table size, to generate the hash value
// assign table [hashvalue]= value
}

最佳答案

首先,您现在应该知道程序的哪一部分速度慢。优化一切都是一个愚蠢的想法,优化快速部分更糟糕。

Math.pow() and % 30000, which is the table size

这是非常错误的。

  • 切勿将浮点运算用于散列之类的操作。它速度慢且分布不良。
  • 切勿使用既不是 2 的幂也不是素数的表格大小。

您没有告诉我们任何有关您要散列的内容以及原因...所以我们假设您需要将一对两个整数映射到表中。

class IntPair {
private int x;
private int y;

public int hashCode() {
// the multiplier must be odd for good results
// its exact value doesn't matter much, but it mustn't equal to your table size; ideally, it should be co-prime
return 54321 * x + y;
}

public boolean equals() {
do yourself
}
}

//// Prime table size. The division is slow, but it works slightly better than power of two.

int[] table = new int[30011]; // this is a prime

int hashCodeToIndex(int hashCode) {
int nonNegative = hashCode & Integer.MAX_VALUE;
return nonNegative % table.length;
}

//// Power of two table size. No division, faster.

int[] table2 = new int[1<<15]; // this is 2**15, i.e., 32768

int smear(int hashCode) {
// doing nothing may be good enough, if the hashCode is well distributed
// otherwise, see e.g., https://github.com/google/guava/blob/c234ed7f015dc90d0380558e663f57c5c445a288/guava/src/com/google/common/collect/Hashing.java#L46
return hashCode;
}

int hashCodeToIndex(int hashCode) {
// the "&" cleans all unwanted bits
return smear(hashCode) & (table2.length - 1);
}

// an alternative, explanation upon request
int hashCodeToIndex2(int hashCode) {
return smear(hashCode) >>> 17;
}

关于Java实现-如何提高哈希表的速度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26052075/

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