Complete Guide: Java Biginteger

In this blog we will learn how to use BigInteger in Java.

Let’s get started!!!

Introduction

BigInteger allows us to work with large integers that exceed range of primitive type like int and long.

int has a max value of 2^31 -1.

long had max value of 2^63-1.

BigInteger can exceed value greater int and long.

Creating BigInteger

We can create BigInteger by specifying the value in the constructor as shown in below example.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
package examples;

import java.math.BigInteger;

public class App {

    public static void main(String[] args) {
        BigInteger bigInteger = new BigInteger("12333585357495344853");
        System.out.println(bigInteger); //12333585357495344853
    }
}

We can also create constant predefined BigInteger values of one, two and ten as shown in below examples

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
package examples;

import java.math.BigInteger;

public class App {

    public static void main(String[] args) {
        BigInteger one = BigInteger.ONE;
        BigInteger two = BigInteger.TWO;
        BigInteger ten = BigInteger.TEN;
        System.out.println(one); //1
        System.out.println(two); //2
        System.out.println(ten); //10

    }
}

Arithmetic Operations

Adding 2 BigInteger numbers

We can add 2 BigInteger numbers by using add() method of the object.

It returns a BigInteger whose value is current object value + value to be added.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
package examples;

import java.math.BigInteger;

public class App {

    public static void main(String[] args) {
        BigInteger num1 = new BigInteger("12333585357495344853");
        BigInteger num2 = new BigInteger("454333585357434344999");
        System.out.println(num1.add(num2)); //466667170714929689852

    }
}

Subtracting 2 BigInteger numbers

We can subtract 2 BigInteger numbers by using subtract() method of the object.

It returns a BigInteger whose value is current object value - value to be subtracted.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
package examples;

import java.math.BigInteger;

public class App {

    public static void main(String[] args) {
        BigInteger num1 = new BigInteger("92333585357495344853");
        BigInteger num2 = new BigInteger("4543335853574343449");
        System.out.println(num1.subtract(num2)); //87790249503921001404

    }
}

Dividing 2 BigInteger numbers

We can divide 2 BigInteger numbers by using divide() method of the object.

It returns a BigInteger whose value is current object value / value to be divided.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
package examples;

import java.math.BigInteger;

public class App {

    public static void main(String[] args) {
        BigInteger num1 = new BigInteger("92333585357495344853");
        BigInteger num2 = new BigInteger("4543335853574343449");
        System.out.println(num1.divide(num2)); //20

    }
}

Multiply operation on 2 BigInteger

We can multiply 2 BigInteger numbers by using multiply() method of the object.

It returns a BigInteger whose value is current object value * value to be multiplied.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
package examples;

import java.math.BigInteger;

public class App {

    public static void main(String[] args) {
        BigInteger num1 = new BigInteger("3242342342");
        BigInteger num2 = new BigInteger("234234");
        System.out.println(num1.multiply(num2)); //759466816136028

    }
}

Advanced operations on BigIntegers

Operation like getting square root of number, raising number to the power of given exponent, getting next possible prime number can also be performed as shown in below examples.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
package examples;

import java.math.BigInteger;

public class App {

    public static void main(String[] args) {
        BigInteger num1 = new BigInteger("3242342342");
        System.out.println(num1.sqrt()); //56941
        System.out.println(num1.pow(2)); //10512783862726044964
        System.out.println(num1.nextProbablePrime()); // 3242342371

    }
}

Generating BigInteger randomly

Constructs a randomly generated BigInteger, uniformly distributed over the range 0 to (2numBits - 1).

The uniformity of the distribution assumes that a fair source of random bits is provided by random object.

It always returns non-negative BigInteger.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
package examples;

import java.math.BigInteger;
import java.util.Random;

public class App {

    public static void main(String[] args) {
        BigInteger num1 = new BigInteger(20, new Random());
        System.out.println(num1); //490906


    }
}

Generating prime numbers randomly

We can generate random prime number based on given bit length using probablePrime() method as shown in below example.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
package examples;

import java.math.BigInteger;
import java.util.Random;

public class App {

    public static void main(String[] args) {
        BigInteger prime1 = BigInteger.probablePrime(50, new Random());
        BigInteger prime2 = BigInteger.probablePrime(3, new Random());
        System.out.println(prime1); //867417845917921
        System.out.println(prime2); //5

    }
}

Comparing BigInteger using compareTo() method

We can compare 2 BigInteger numbers using compareTo() method as shown in below example.

It returns -1, 0 or 1 as this BigInteger is numerically less than, equal to, or greater than val respectively.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
package examples;

import java.math.BigInteger;

public class App {

    public static void main(String[] args) {
        BigInteger num1 = new BigInteger("3827238764238");
        BigInteger num2  = new BigInteger("34234234");
        System.out.println(num1.compareTo(num2));

    }
}

Converting BigInteger to other data types

We can convert BigInteger to data types like int,long and float as shown in below examples.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
package examples;

import java.math.BigInteger;

public class App {

    public static void main(String[] args) {
        BigInteger num1 = new BigInteger("324234");
        System.out.println(num1.intValue()); //324234
        System.out.println(num1.longValue()); //324234
        System.out.println(num1.floatValue()); // 324234.0

    }
}

BitWise operations

We can perform bitwise OR , bitwise AND and bitwise XOR operations as shown in below examples

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
package examples;

import java.math.BigInteger;

public class App {

    public static void main(String[] args) {
        BigInteger num1 = new BigInteger("10");
        BigInteger num2  = new BigInteger("20");
        System.out.println(num1.or(num2)); //30
        System.out.println(num1.and(num2)); // 0
        System.out.println(num1.xor(num2)); // 30

    }
}

Conclusion

I hope this tutorial helps you to get complete understanding of BigInteger.

Thanks!!