Neste problema simples, é pedido que trabalhemos com números grandes (BigInteger) e que imprimamos a soma de um BI com o outro e a multiplicação dos dois.
Um BigInteger
não é um tipo primitivo. Tanto ele quanto um BigNumber
ou BigDecimal
são classes do pacote java.math
e por isso contam com métodos para fazer soma e multiplicação, por exemplo.
O método .add()
vem da Interface Set
e é utilizado não só como soma, mas também como um tipo de verificação. O método, além de devolver o resultado matemático, também devolve um boolean
e não soma valores duplicados ou algum valor null
.
Já o método .multiply()
vem diretamente do pacote java.math.BigInteger.
=========
Assim, o resultado desse exercício é:
public class Solution {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
BigInteger firstBI = sc.nextBigInteger();
BigInteger secondBI = sc.nextBigInteger();
sc.close();
System.out.println(firstBI.add(secondBI));
System.out.println(firstBI.multiply(secondBI));
}
}
=========
Referências:
Add : Oracle
Multiply : Oracle
============
Essa publicação faz parte de uma série de exercícios resolvidos em Java no HackerRank. Acesse a série completa:
- HackerRank #6 | Scanner e End-of-file
- HackerRank #7 | Int to String / String to Int
- HackerRank #8 | Date and Time
- HackerRank #9 | Static Initializer Block
- HackerRank #10 | Currency Formatter
- HackerRank #11 | DataTypes
- HackerRank #12 | Strings Introduction
- HackerRank #13 | Substring Comparisons
- HackerRank #14 | Abstract Class
- HackerRank #18 | BigInteger
- HackerRank #19 | Loops II
- HackerRank #20 | String Reverse
- HackerRank #23 | Instanceof keyword
- HackerRank #26 | Generics
- HackerRank #27 | 1D Array
- HackerRank #28 | Anagrams
- HackerRank #33 | Arraylist
- HackerRank #34 | Exception Handling Try / Catch
- HackerRank #36 | Exception Handling
- HackerRank #37 | List
- HackerRank #38 | SubArray
- HackerRank #39 | HashSet
- HackerRank #40 | Java Dequeue
Top comments (0)