Grandes números em Java
-
21-08-2019 - |
Pergunta
Como é que eu vou fazer cálculos com números extremamente grandes em Java?
Eu tentei long
mas que consegue no máximo 9223372036854775807, e quando se utiliza um inteiro ele não salva dígitos suficientes e, portanto, não é suficiente preciso para o que eu preciso.
Existe uma maneira de contornar isso?
Solução
Você pode usar a classe BigInteger
para inteiros e BigDecimal
para números com dígitos decimais. Ambas as classes são definidas no pacote java.math
.
Exemplo:
BigInteger reallyBig = new BigInteger("1234567890123456890");
BigInteger notSoBig = new BigInteger("2743561234");
reallyBig = reallyBig.add(notSoBig);
Outras dicas
Use a classe BigInteger
que é uma parte da biblioteca Java.
http: //java.sun. com / J2SE / 1.5.0 / docs / api / java / matemática / BigInteger.html
Aqui está um exemplo que recebe grandes números muito rapidamente.
import java.math.BigInteger;
/*
250000th fib # is: 36356117010939561826426 .... 10243516470957309231046875
Time to compute: 3.5 seconds.
1000000th fib # is: 1953282128707757731632 .... 93411568996526838242546875
Time to compute: 58.1 seconds.
*/
public class Main {
public static void main(String... args) {
int place = args.length > 0 ? Integer.parseInt(args[0]) : 250 * 1000;
long start = System.nanoTime();
BigInteger fibNumber = fib(place);
long time = System.nanoTime() - start;
System.out.println(place + "th fib # is: " + fibNumber);
System.out.printf("Time to compute: %5.1f seconds.%n", time / 1.0e9);
}
private static BigInteger fib(int place) {
BigInteger a = new BigInteger("0");
BigInteger b = new BigInteger("1");
while (place-- > 1) {
BigInteger t = b;
b = a.add(b);
a = t;
}
return b;
}
}
Checkout BigDecimal
e BigInteger
.
import java.math.BigInteger;
import java.util.*;
class A
{
public static void main(String args[])
{
Scanner in=new Scanner(System.in);
System.out.print("Enter The First Number= ");
String a=in.next();
System.out.print("Enter The Second Number= ");
String b=in.next();
BigInteger obj=new BigInteger(a);
BigInteger obj1=new BigInteger(b);
System.out.println("Sum="+obj.add(obj1));
}
}
Dependendo do que você está fazendo que você gostaria de dar uma olhada em GMP (gmplib.org), que é uma biblioteca multi-precisão de alto desempenho. Para usá-lo em Java você precisa wrappers JNI em torno da biblioteca binário.
Veja alguns dos códigos Alioth Shootout para um exemplo de usá-lo em vez de BigInteger para calcular Pi para um número arbitrário de dígitos.
https: //benchmarksgame-team.pages .debian.net / benchmarksgame / programa / pidigits-java-2.html
usando tipo de dados string que você facilmente resolver esta questão.
class Account{
String acc_no;
String name;