有没有办法在java中获得长度超过整数数据类型支持的数组?java中的任意数组长度
我正在寻找一些可能使用Java中的大整数进行索引的东西,因为本机支持的数组长度远不及我需要的那样大,因为我正在实现的算法。
有没有办法在java中获得长度超过整数数据类型支持的数组?java中的任意数组长度
我正在寻找一些可能使用Java中的大整数进行索引的东西,因为本机支持的数组长度远不及我需要的那样大,因为我正在实现的算法。
Int32为您提供 8千兆字节的存储空间。你有这么多的记忆吗?
我认为你应该使用稀疏数组,即散列索引元素。例如,只有HashMap<BigInteger,YourValueType>
或类似BigMemory一些库和替代http://terracotta.org/products/bigmemory
是否有可能您不应该使用数组实现此算法?你能告诉我们关于算法的一些信息吗?顺便说一句,你总是可以在你自己的类中实现一个分块数组,并且这个分块有很长的索引,但我认为重新考虑算法实现可能会更好。 –
如果可能,我需要数组,因为它们更快;该阵列是一种新的主筛选算法,它与数列的长度相等,这意味着在第一次运行之后,长度将大于9699690. – Adam
您打算如何使筛子产生质数?难道你通常只会去65,000或某些类似的东西,然后用一些主要的素数来测试比那更大的素数?数组将如何使用?如果你要做一些类似“getNearestPrime(N)”的操作,那么在实现这个方法时,你可以通过mod操作来找到解决方案所在的阵列。这将允许你使用多个数组。 –